jQuery的ajax中使用FormData实现页面无刷新上传功能

发布时间 - 2026-01-10 22:32:53    点击率:

接着上一篇ajax系列之用jQuery的ajax方法向服务器发出get和post请求写,这篇主要写如何利用ajax和FormData实现页面无刷新的文件上传效果,主要用到了jQuery的ajax()方法和XMLHttpRequest Level 2的FormData接口。关于FormData,大家可以看MDN文档。

1,先看效果图

期望的功能和效果很简单:点击页面中的上传文件表单控件,选择文件后点击“ajax提交”,将文件上传至服务器,上传成功后,页面给出一个简单的提示。

2,前端的代码

看下html代码:     

 <div class="box">
    <div>
     <div class="item">
      <input type="file" name="myfile" style="font-size: 0.7rem;">
     </div>
     <div class="item">
      <button type="button" style="display: block; padding: 4px 18px;" class="btn-default">ajax提交</button>
     </div>
     <div class="item">
      <button type="submit" style="display: block; padding: 4px 18px;" class="btn-default">form提交</button>
     </div>
    </div>
    <div class="prompt" style="font-size: 0.7rem;"></div>
   </div>
   <script src="../../js/jquery-3.1.0.min.js"></script>
   <script src="upload01.js"></script>

代码很简单,需要注意的是页面中没有用到form表单,那么怎么提交数据呢,答案是用FormData来模拟表单中的 <input type="file" name="myfile"> 控件。另外,页面中的样式没有写出来。下面来看下html中引入的upload01.js代码,这个是重点。

upload01.js代码:

 $(function($) {
  $('input[name=myfile]').on('change', function(e) {
   $('button[type=button]').on('click', function(e) {
    var formData = new FormData();
    // formData.ppend(name, element);
    formData.append('myfile', $('input[name=myfile]')[0].files[0]);
    $.ajax({
     url: 'upload.php',
     method: 'POST',
     data: formData,
     contentType: false, // 注意这里应设为false
     processData: false,
     cache: false,
     success: function(data) {
     if (JSON.parse(data).result == 1) {
       $('.prompt').html(`文件${JSON.parse(data).filename}已上传成功`);
      }
     },
     error: function (jqXHR) {
      console.log(JSON.stringify(jqXHR));
     }
    })
    .done(function(data) {
     console.log('done');
    })
    .fail(function(data) {
     console.log('fail');
    })
    .always(function(data) {
     console.log('always');
    });
   });
  });
 });

(1) 下面解释下FormData,涉及到了代码的第4、6、10行。

第4行 var formData = new FormData(); 实例化了一个空的FormData对象,可以认为它就是一个form表单,但现在里面什么控件都没有。

第6行 formData.append('myfile', $('input[name=myfile]')[0].files[0]); ,给实例化的formdata对象添加一个控件,注意这里添加的是已有控件 <input type="file" name="myfile" style="font-size: 0.7rem;"> (见html代码第4行)。

FormData.append(name, value, filename)方法可以很方便的以“键-值”对的形式给FormData添加控件,注意第3个参数“上传文名”是可选的,它的具体语法和用法见FormData。

第10行,将实例化的formData作为jQuery.ajax()方法data参数的值传递进去,提交给后端服务器。

(2) 再解释下ajax()方法中的contentType、processData参数。

contentType参数,发起http请求时设置的请求头中的contentType。jQuery.ajax()默认的值为:'application/x-www-form-urlencoded; charset=UTF-8',这个在大多数情况下都是适用的。

但经过测试,保持默认时会报错,因为发送的数据中有input type="file"(上传文件),那么这时contentType应该设置为'multipart/form-data',但如果指定为这个类型服务端(php)就会报这个错误: Warning: Missing boundary in multipart/form-data POST data in Unknown on line 0 。具体原因现在还不清楚,所以这里先将contentType设置为false,即不让jQuery设置contentType。

processData参数,根据jQuery.ajax()文档中的解释,默认情况下,jQuery会处理发送的数据,将数据按照'application/x-www-form-urlencoded'的要求转换为查询字符串,如果要发送的数据是DOMDocument或者不需要处理,就可以设置为false不让jQuery转换数据,我们这里要发送的数据其实就是DOMDocument。

经过测试,如果保持默认(true)的话,在发起请求前js会报错: TypeError: 'append' called on an object that does not implement interface FormData.

另外还有个dataType参数,期望从服务器中返回的数据格式,这里最好也不要指定,而是让jquery自己根据http响应头中的contentType判断,然后返回一个合适的数据类型。指定后不会影响后台程序的逻辑处理,但你在前端接收的数据很可能不是期望的数据,于是js就会报这一类错误: SyntaxError: JSON.parse: unexpected character at line 1 column 2 of the JSON data ,这个是将dataType指定为json后报的错误。

3,后端的php代码

后端服务器是nginx,用php来处理发送过来的数据,代码也很简单:

 <?php
 // var_dump($_REQUEST); // 为空数组
 // var_dump($_FILES); //不为空 
 // 当使用FormData配合ajax上传文件时,$_REQUEST、$_POST都是null,php://input也是null
 if (isset($_FILES) && !empty($_FILES)) {
  if (move_uploaded_file($_FILES['myfile']['tmp_name'], $_FILES['myfile']['name'])) {
   echo '{"result": 1, "filename": "' . $_FILES['myfile']['name'] . '"}';
  } else {
   echo '{"result": 0}';
  }
 }

代码的逻辑很简单这里就不多解释了。主要说下我在调试程序时遇到的问题,遇到的问题总结起来就一句话:当使用FormData配合ajax上传文件时,$_REQUEST、$_POST都是空数组,php://input也是null。可以看到,我在代码中的第2、3、5行也写了相关的注释。为什么$_REQUEST会是空呢?我查了些资料,但没找到原因,以后再找原因吧。

以上所述是小编给大家介绍的jQuery的ajax中使用FormData实现页面无刷新上传功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# jquery  # ajax  # formdata  # formdata无刷新上传  # jQuery利用FormData上传文件实现批量上传  # jquery使用FormData实现异步上传文件  # jQuery Ajax使用FormData上传文件和其他数据后端web.py获取  # jQuery用FormData实现文件上传的方法  # jQuery Ajax使用FormData对象上传文件的方法  # jQuery+formdata实现上传进度特效遇到的问题  # JQuery基于FormData异步提交数据文件  # 都是  # 会报  # 表单  # 很简单  # 上传文件  # 的是  # 设置为  # 上传  # 我在  # 后端  # 报错  # 小编  # 为空  # 是一个  # 文档  # 有个  # 在此  # 不需要  # 已有  # 还不 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何使用Eloquent ORM进行数据库操作?(CRUD示例)  如何快速生成高效建站系统源代码?  Python制作简易注册登录系统  高性价比服务器租赁——企业级配置与24小时运维服务  Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理  如何在阿里云完成域名注册与建站?  HTML5空格和nbsp有啥关系_nbsp的作用及使用场景【说明】  HTML 中如何正确使用模板变量为元素的 name 属性赋值  Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用  用yum安装MySQLdb模块的步骤方法  怎么用AI帮你设计一套个性化的手机App图标?  Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)  如何快速生成橙子建站落地页链接?  如何实现建站之星域名转发设置?  如何快速建站并高效导出源代码?  Windows驱动无法加载错误解决方法_驱动签名验证失败处理步骤  HTML透明颜色代码怎么让图片透明_给img元素加透明色的技巧【方法】  *服务器网站为何频现安全漏洞?  Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】  Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】  如何挑选最适合建站的高性能VPS主机?  Laravel Eloquent:优雅地将关联模型字段扁平化到主模型中  html5audio标签播放结束怎么触发事件_onended回调方法【教程】  网站制作报价单模板图片,小松挖机官方网站报价?  laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法  JavaScript中如何操作剪贴板_ClipboardAPI怎么用  Laravel如何配置Horizon来管理队列?(安装和使用)  如何快速搭建高效简练网站?  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环  如何快速上传建站程序避免常见错误?  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  如何用好域名打造高点击率的自主建站?  如何在建站主机中优化服务器配置?  Laravel怎么使用artisan命令缓存配置和视图  python中快速进行多个字符替换的方法小结  如何快速使用云服务器搭建个人网站?  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  Angular 表单中正确绑定输入值以确保提交与验证正常工作  HTML5空格和margin有啥区别_空格与外边距的使用场景【说明】  Laravel怎么在Blade中安全地输出原始HTML内容  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  javascript读取文本节点方法小结  Laravel如何使用缓存系统提升性能_Laravel缓存驱动和应用优化方案  Bootstrap整体框架之JavaScript插件架构  小米17系列还有一款新机?主打6.9英寸大直屏和旗舰级影像  如何在Windows环境下新建FTP站点并设置权限?  简历在线制作网站免费版,如何创建个人简历?  Laravel如何使用Service Container和依赖注入?(代码示例)  Laravel如何实现图片防盗链功能_Laravel中间件验证Referer来源请求【方案】