首页 > web前端 > js教程 > ajax怎么使文件与图片异步上传

ajax怎么使文件与图片异步上传

php中世界最好的语言
发布: 2018-04-25 14:28:32
原创
1609 人浏览过

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

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

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

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

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

1

2

3

4

5

6

7

8

9

 <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>

登录后复制

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

1

2

3

4

5

6

7

8

9

10

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请求提交给后台:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

  //创建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=&#39;"+obj.msg+"&#39; alt=&#39;&#39; />");

    $(".con").append(img);

    imgs.push(obj.msg);

   }else{

    alert(obj.msg);

   }

   }

  }

  }

 });

登录后复制

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

<?php

//解决跨域问题

header("Access-Control-Allow-Origin:*");

//说明向前台返回的数据类型为JSON

header("Content-type:text/json");

//$_FILES超全局变量存储是文件数据,是一个关联数组

 $fileObj=$_FILES[&#39;file&#39;];

 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);

 }

?>

登录后复制

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

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

//完成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);

  }

  });

 });

登录后复制

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

推荐阅读:

jQuery实现异步刷新

jQuery怎样向服务器发出get和post请求

以上是ajax怎么使文件与图片异步上传的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
angular.js - Angularjs $http ajax问题?
来自于 1970-01-01 08:00:00
0
0
0
ajax点击提交没反应!
来自于 1970-01-01 08:00:00
0
0
0
javascript - autocomplete ajax怎么配置,求教
来自于 1970-01-01 08:00:00
0
0
0
ajax 学习需要什么基础
来自于 1970-01-01 08:00:00
0
0
0
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板