ajax提交form表单上传文件(ajax实现文件上传)

IE浏览器版本最好为:IE10+,因为 FormData 兼容性问题

然后查看示例,代码如下↓

html 代码:

  1. <!DOCTYPE html>
  2. <html lang="zh-cn">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. <script type="text/javascript" src="jquery-1.8.3.min.js"></script>
  7. <style type="text/css">
  8. #showimg{margin-top: 20px;height: 150px;}
  9. #showimg div{width: 100px;height: 100px;line-height:100px;margin-right: 20px;float: left;text-align: center;}
  10. #showimg img{vertical-align: middle;max-width: 100%;max-height: 100%;}
  11. </style>
  12. <script type="text/javascript">
  13. jQuery(function () {
  14. jQuery('#butSubmit').click(function () {
  15. var file = jQuery('#fileId')[0].files;
  16. var formDataInfo = new FormData(jQuery('#FormDataUpload')[0]);
  17. formDataInfo.append('file',file);//表单数据
  18. formDataInfo.append('ajajxfile', 1);//额外加数据
  19. /*------分割线------*/
  20. // var formDataInfo = new FormData();
  21. // formDataInfo.append('pic', jQuery("#picId")[0].files[0]);
  22. // formDataInfo.append('ajajxfile', 1);//额外加数据
  23. //jQuery.each(jQuery("#fileId")[0].files,function (k,val) {
  24. // formDataInfo.append('fileimg[]', val);
  25. // });
  26. // alert(formData);
  27. jQuery.ajax({
  28. type:'post',
  29. url:'upload.php',
  30. dataType:'json',
  31. cache:false,
  32. processData:false,//必须
  33. contentType:false,//必须
  34. data:formDataInfo,
  35. success:function (data) {
  36. // alert(data);
  37. var html = '';
  38. for (var i=0;i<data.length;i++){
  39. html +='<div><img src="'+data[i]+'"></div>';
  40. }
  41. jQuery('#showimg').html(html);
  42. },
  43. error:function () {
  44. alert('Error');
  45. }
  46. });
  47. });
  48. });
  49. </script>
  50. </head>
  51. <body>
  52. <br>
  53. <form action="upload.php" method="post" enctype="multipart/form-data">
  54. <input name="img[]" type="file" multiple>
  55. <!--<input name="picId" type="file" >-->
  56. <input type="button" value="提交" >
  57. <!-- <input type="submit" name="dosubmit" value="提交Form">-->
  58. </form>
  59. <div ></div>
  60. </body>
  61. </html>

后台程序 PHP代码:

  1. <?php
  2. date_default_timezone_set('PRC');
  3. if (!empty($_POST)){
  4. if ($_FILES['img']['name'][0]){
  5. $path = 'upload/';
  6. if (!is_dir($path)){
  7. mkdir(iconv("UTF-8", "GBK", $path),0777,true);
  8. }
  9. $datafile = $_FILES['img'];
  10. $filearr = array();
  11. foreach ($datafile['name'] as $key=>$value){
  12. $type = pathinfo($value);
  13. $filename = $path.time().mt_rand(0,999999999).'.'.$type['extension'];
  14. if (move_uploaded_file($datafile['tmp_name'][$key],$filename)){
  15. $filearr[] = $filename;
  16. }
  17. }
  18. print_r(json_encode($filearr));die;
  19. }
  20. }

一个简单的ajax上传文件,欢迎广大朋友们一起来学习!

ajax提交form表单上传文件(ajax实现文件上传)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发表评论

登录后才能评论