最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

异步的文件或图片上传ajax

来源:动视网 责编:小采 时间:2020-11-27 19:56:51
文档

异步的文件或图片上传ajax

异步的文件或图片上传ajax:这次给大家带来异步的文件或图片上传ajax,异步文件或图片上传ajax的注意事项有哪些,下面就是实战案例,一起来看一下。众所周知现在的各大网站基本都设有文件上传功能,用户可以把自己喜欢的图片或其他文件放在网上存起来,以便以后用的时候方便去找,可是一
推荐度:
导读异步的文件或图片上传ajax:这次给大家带来异步的文件或图片上传ajax,异步文件或图片上传ajax的注意事项有哪些,下面就是实战案例,一起来看一下。众所周知现在的各大网站基本都设有文件上传功能,用户可以把自己喜欢的图片或其他文件放在网上存起来,以便以后用的时候方便去找,可是一


这次给大家带来异步的文件或图片上传ajax,异步文件或图片上传ajax的注意事项有哪些,下面就是实战案例,一起来看一下。

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

其实文件上传有两种方法,一种是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>
 <p class="con"></p>

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

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='"+obj.msg+"' alt='' />");
 $(".con").append(img);
 imgs.push(obj.msg);
 }else{
 alert(obj.msg);
 }
 }
 }
 }
 });

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

<?php
//解决跨域问题
header("Access-Control-Allow-Origin:*");
//说明向前台返回的数据类型为JSON
header("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);
 }
 });
 });

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

ajax传递json时为什么会出现乱码

新手必学的Ajax总结

文档

异步的文件或图片上传ajax

异步的文件或图片上传ajax:这次给大家带来异步的文件或图片上传ajax,异步文件或图片上传ajax的注意事项有哪些,下面就是实战案例,一起来看一下。众所周知现在的各大网站基本都设有文件上传功能,用户可以把自己喜欢的图片或其他文件放在网上存起来,以便以后用的时候方便去找,可是一
推荐度:
标签: 图片 文件 上传
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top