侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

ajax实现异步文件或图片上传功能

前端  /  管理员 发布于 4年前   428

大家好,这篇文章我要给大家分享一个网页文件上传功能的代码,希望大家可以有所参考,或者给我提些建议。

众所周知现在的各大网站基本都设有文件上传功能,用户可以把自己喜欢的图片或其他文件放在网上存起来,以便以后用的时候方便去找,可是一个网页的文件上传功能究竟该怎么去设置呢?今天我就以图片上传为例向大家展示文件上传功能的具体步骤。

其实文件上传有两种方法,一种是from表单submit提交,一种是ajax实现异步提交,可是form表单提交有个问题就是每次在上传完成时会刷新界面,不能实现异步上传,所以现在几乎所有网站都采用ajax异步上传,现在我给大家展示ajax异步上传该如何实现。

首先我先创建一个form表单,代码如下:

 <form action="" id="form">  用户名:<input type="text" name="user"/></br>  密码:<input type="password" name="pass" /></br>  性别:<input type="radio" name="sex" value="男"/>男   <input type="radio" name="sex" value="女"/>女  头像:<input type="file" id="file" name="file"/></br>  <button id="btn" type="button">提交</button> </form> <div class="con"></div>

创建完成后,首先我们要先拿到用户从本上传的图片的信息,代码如下

var imgs=[];//存储图片链接 //为文件上传添加change事件 var fileM=document.querySelector("#file"); $("#file").on("change",function(){  console.log(fileM.files);  //获取文件对象,files是文件选取控件的属性,存储的是文件选取控件选取的文件对象,类型是一个数组  var fileObj=fileM.files[0];  //创建formdata对象,formData用来存储表单的数据,表单数据时以键值对形式存储的。  var formData=new FormData();  formData.append('file',fileObj);

这里的formData就是我们现在要的存储文件信息的对象,然后我们需要把它用ajax请求提交给后台:

  //创建ajax对象  var ajax=new XMLHttpRequest();  //发送POST请求  ajax.open("POST","http://localhost/phpClass/file-upload/move_file.php",true);  ajax.send(formData);  ajax.onreadystatechange=function(){  if (ajax.readyState == 4) {   if (ajax.status>=200 &&ajax.status<300||ajax.status==304) {   console.log(ajax.responseText);   var obj=JSON.parse(ajax.responseText);   alert(obj.msg);   if(obj.err == 0){、    //上传成功后自动动创建img标签放在指定位置    var img =$("<img src='//article/"+obj.msg+"' alt='' />");    $(".con").append(img);    imgs.push(obj.msg);   }else{    alert(obj.msg);   }   }  }  } });

然后我们请求成功后,后台肯定要做出相应的处理,并且把图片存到指定的文件夹里,所以相应的PHP应该完成这些操作:

<?php//解决跨域问题header("Access-Control-Allow-Origin:*");//说明向前台返回的数据类型为JSONheader("Content-type:text/json");//$_FILES超全局变量存储是文件数据,是一个关联数组 $fileObj=$_FILES['file']; var_dump($fileObj); if($fileObj["error"]==0){ //判断文件是否合法 $types=["jpg","jpeg","png","gif"]; $type = explode("/", $fileObj["type"])[1]; if(in_array($type, $types)){  $time = time();//获取时间戳 返回一个整形  //获取文件详细路径  $filePath="http://localhost/phpClass/image1".$time.".".$type;  echo $filePath;  //移动文件  $res=move_uploaded_file($fileObj["tmp_name"],"../image1/".$time.".".$type);  if($res){  $infor=array("err"=>0,"msg"=>"文件移动成功");  }else{  $infor=array("err"=>1,"msg"=>"文件移动失败");  } }else{  $infor=array("err"=>1,"msg"=>"文件格式不合法"); } echo json_encode($infor); }?>

这样我们就完成了文件上传的所有步骤,如果你想把自己喜欢的图片,上传到自己的网页上,希望这段代码可以帮助到你!

附:如果上传文件时还要附带上你的其它信息,你只需再前端页面请求完成后加上这段代码即可实现:

//完成form表单数据的提交 $('#btn').on('click',function(){//  serializeArray()将form表单控件中的数据序列化成数组,数组中含有若干对象,对象包含对应控件的name和value  var infor = $('#form').serializeArray();//  console.log(infor);  var stu = {};  for (var i=0;i<infor.length;i++) {  var obj=infor[i];  stu[obj.name] = obj.value;  }  stu["imgs"] = imgs;  stu["imgs"] = imgs[0];  //发送ajax请求  $.ajax({  url:"http://localhost/phpClass/file-upload/data.php",  data:{   parameter :JSON.stringify(stu)  },  success:function(res){   console.log(res.msg);  }  }); });

更多精彩内容请参考专题《ajax上传技术汇总》进行学习。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


  • 上一条:
    AJAX用于判定用户是否注册
    下一条:
    struts2+jquery实现ajax登陆实例详解
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 使用 Alpine.js 排序插件对元素进行排序(0个评论)
    • 在js中使用jszip + file-saver实现批量下载OSS文件功能示例(0个评论)
    • 在vue中实现父页面按钮显示子组件中的el-dialog效果(0个评论)
    • 使用mock-server实现模拟接口对接流程步骤(0个评论)
    • vue项目打包程序实现把项目打包成一个exe可执行程序(0个评论)
    • 近期文章
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-03
    • 2018-04
    • 2018-05
    • 2018-06
    • 2018-09
    • 2018-11
    • 2018-12
    • 2019-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2021-04
    • 2021-05
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客