欢迎来到小居数码网-一家分享数码知识,生活小常识的网站,希望可以帮助到您。

当前位置:生活小常识 > 数码知识 >
优质

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

数码知识

孙小伟优秀作者

原创内容 来源:小居数码网 时间:2024-08-12 17:06:01 阅读() 收藏:48 分享:61

导读:您正在阅读的是关于【数码知识】的问题,本文由科普作家协会,生活小能手,著名生活达人等整理监督编写。本文有825个文字,大小约为3KB,预计阅读时间3分钟。

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

ajax提交form表单上传文件

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

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表单上传文件)的全部内容,希望可以帮助到你,想了解更多关于数码知识的问题,欢迎关注我们,并收藏,转发,分享。

94%的朋友还想知道的:

(221)个朋友认为回复得到帮助。

部分文章信息来源于以及网友投稿,转载请说明出处。

本文标题:ajax实现文件上传(ajax提交form表单上传文件):http://sjzlt.cn/shuma/155003.html

猜你喜欢