全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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>
 <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='"+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);
  }
  });
 });

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

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


# ajax文件上传  # ajax异步文件上传  # ajax图片上传  # 图片异步上传  # 更新实例  # ajax 异步上传带进度条视频并提取缩略图  # Ajax异步文件上传与NodeJS express服务端处理  # Ajax异步上传文件实例代码分享  # ajax实现文件异步上传并回显文件相关信息功能示例  # jquery中的ajax异步上传  # Ajax表单异步上传文件实例代码(包括文件域)  # 表单上传功能实现 ajax文件异步上传  # ajax异步实现文件分片上传实例代码  # 表单  # 文件上传  # 上传  # 是一个  # 放在  # 这段  # 自己喜欢  # 自己的  # 的是  # 如果你  # 我要  # 给我  # 完成后  # 有个  # 只需  # 各大  # 去找  # 给大家  # 到你  # 我给 


相关文章: 如何有效防御Web建站篡改攻击?  怀化网站制作公司,怀化新生儿上户网上办理流程?  测试制作网站有哪些,测试性取向的权威测试或者网站?  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  制作网站的软件免费下载,免费制作app哪个平台好?  动图在线制作网站有哪些,滑动动图图集怎么做?  临沂网站制作企业,临沂第三中学官方网站?  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  如何正确选择百度移动适配建站域名?  如何在云主机上快速搭建多站点网站?  如何用虚拟主机快速搭建网站?详细步骤解析  建站之星价格显示格式升级,你的预算足够吗?  在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  创业网站制作流程,创业网站可靠吗?  贸易公司网站制作流程,出口贸易网站设计怎么做?  网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?  制作营销网站公司,淘特是干什么用的?  攀枝花网站建设,攀枝花营业执照网上怎么年审?  如何通过cPanel快速搭建网站?  如何在Golang中处理模块冲突_解决依赖版本不兼容问题  三星网站视频制作教程下载,三星w23网页如何全屏?  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  活动邀请函制作网站有哪些,活动邀请函文案?  成都响应式网站开发,dw怎么把手机适应页面变成网页?  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?  独立制作一个网站多少钱,建立网站需要花多少钱?  香港服务器租用每月最低只需15元?  如何彻底删除建站之星生成的Banner?  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  高端智能建站公司优选:品牌定制与SEO优化一站式服务  如何通过虚拟主机快速搭建个人网站?  视频网站制作教程,怎么样制作优酷网的小视频?  如何在阿里云ECS服务器部署织梦CMS网站?  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  如何在阿里云域名上完成建站全流程?  c++怎么用jemalloc c++替换默认内存分配器【性能】  如何在万网ECS上快速搭建专属网站?  如何挑选优质建站一级代理提升网站排名?  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  免费视频制作网站,更新又快又好的免费电影网站?  如何选择高效可靠的多用户建站源码资源?  Python路径拼接规范_跨平台处理说明【指导】  如何在IIS中新建站点并解决端口绑定冲突?  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  昆明高端网站制作公司,昆明公租房申请网上登录入口?  企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。