使用jquery Ajax实现上传附件功能


Posted in jQuery onOctober 23, 2018

用过jquery的Ajax的人肯定都知道,Ajax的默认编码方式是”application/x-www-form-urlencoded“,此编码方式只能编码文本类型的数据,因此Ajax发送请求的时候,会把data序列化成 一个个String类型的键值对,此种传输数据的方式能够满足大部分应用场景,然而当传输的数据里有附件的时候,此序列化机制便是我们的绊脚石。Ajax本身的序列化机制的硬伤归其原因在于在html4的时代,没有FileReader接口,在页面里无法读取File(Blob)文件,用document.getElementById("文件控件的id").value只能拿到文件的name,因此去序列化去编码它也无从谈起(个人观点,有不同意见的欢迎给我留言)。

众所周知,用form提交表单的时候,有附件的时候,只要设置form的enctype="multipart/form-data",便可以上传附件。于是博主想到,若是能用Ajax提交一个form,那上传附件岂不是变的简单,再也不需要使用类似AjaxFileUpload之类的插件来作上传。html5让这一切便的简单。

FormData是html5的接口,使用它一行代码便可以拿到整个form表单对象:

     var form = new FormData(document.getElementById("form"));

然后我们拿着这个form对象,去赋给Ajax的data,并且阻止它将参数转成成String类型的键值对,此举需要设置processData属性为false,此属性默认为true;同时设置Ajax的编码方式为false(contentType: false),在form表单里已经设置了编码方式,Ajax的编码机制已经不需要,这样我们就可以用Ajax去提交一个form对象,从而解决表单有附件的问题。需要注意的是,务必将Ajax的提交方式,设置为post,get请求只能携带几kb的数据。若是不设置processData为false,去提交带附件的form同样是提交不上去的,它的序列化机制是硬伤。所以提交的时候,只能不使用它的序列化机制。

一言以蔽之:借Ajax的壳,去提交form。

示例如下:

<!DOCTYPE html>
<html>
<head>
  <script src="js/jquery-1.9.1.min.js"></script>
  <meta charset="utf-8" />
  <title>Ajax提交form</title>
  <script type="text/javascript">
  function test(){
   var form = new FormData(document.getElementById("form"));
   $.ajax({
   url:"接口地址",
   type:"post",
   data:form,
   cache: false,
   processData: false,
   contentType: false,
   success:function(data){
      alert("操作成功!");
   },
   error:function(e){
     alert("网络错误,请重试!!");
    }
   });    
  }
</script>
</head>
<body>
<form id="form" enctype="multipart/form-data">
  <input type="text" id="name" name="name" />
  <input type="text" id="phone" name="phone" />
  <input type="text" id="content" name="content" />
  <input type="text" id="price" name="price" />
  <input type="text" id="ifPhone" name="ifPhone" />
  <input type="text" id="ifCerName" name="ifCerName" />
  <input type="text" id="endTime" name="endTime" />
  <input type="text" id="type" name="type" />
<input type="file" id="fileAttach" name="fileAttach" />
<input type="button" onclick="test()" value="上传" />
</form>
</body>
</html>

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

jQuery 相关文章推荐
jQuery实现动态生成表格并为行绑定单击变色动作的方法
Apr 17 jQuery
jQuery树插件zTree使用方法详解
May 02 jQuery
详解如何在 vue 项目里正确地引用 jquery 和 jquery-ui的插件
Jun 01 jQuery
利用jquery去掉时光轴头尾部线条的方法实例
Jun 16 jQuery
jQuery remove()过滤被删除的元素(推荐)
Jul 18 jQuery
jQuery响应滚动条事件功能示例
Oct 14 jQuery
JS和JQuery实现雪花飘落效果
Nov 30 jQuery
jQuery+CSS实现的标签页效果示例【测试可用】
Aug 14 jQuery
jQuery使用ajax传递json对象到服务端及contentType的用法示例
Mar 12 jQuery
JQuery省市联动效果实现过程详解
May 08 jQuery
基于jQuery拖拽事件的封装
Nov 29 jQuery
jquery实现穿梭框功能
Jan 19 jQuery
jquery实现动态添加附件功能
Oct 23 #jQuery
jQuery.validate.js表单验证插件的使用代码详解
Oct 22 #jQuery
jQuery轻量级表单模型验证插件
Oct 15 #jQuery
jquery实现联想词搜索框和搜索结果分页的示例
Oct 10 #jQuery
jQuery 获取除某指定对象外的其他对象 ( :not() 与.not())
Oct 10 #jQuery
jquery.param()实现数组或对象的序列化方法
Oct 08 #jQuery
jQuery实现点击图标div循环放大缩小功能
Sep 30 #jQuery
You might like
PHP 压缩文件夹的类代码
2009/11/05 PHP
开源php中文分词系统SCWS安装和使用实例
2014/04/11 PHP
PHP常用的三种设计模式汇总
2016/08/28 PHP
详解PHP防止直接访问.php 文件的实现方法
2017/07/28 PHP
PHP将英文数字转换为阿拉伯数字实例讲解
2019/01/28 PHP
HTML TO JavaScript 转换
2006/06/26 Javascript
JavaScript入门教程 Cookies
2009/01/31 Javascript
JS无法捕获滚动条上的mouse up事件的原因猜想
2012/03/21 Javascript
用IE重起计算机或者关机的示例代码
2014/03/10 Javascript
jQuery中prepend()方法使用详解
2015/08/11 Javascript
jquery 判断selection range 是否在容器中的简单实例
2016/08/02 Javascript
NODE.JS跨域问题的完美解决方案
2016/10/20 Javascript
vue监听滚动事件实现滚动监听
2017/04/11 Javascript
vue2.0模拟锚点的实例
2018/03/14 Javascript
在angular 6中使用 less 的实例代码
2018/05/13 Javascript
详解微信小程序调起键盘性能优化
2018/07/24 Javascript
JavaScript函数apply()和call()用法与异同分析
2018/08/10 Javascript
JavaScript中Dom操作实例详解
2019/07/08 Javascript
python中as用法实例分析
2015/04/30 Python
Python中处理字符串之isalpha()方法的使用
2015/05/18 Python
unittest+coverage单元测试代码覆盖操作实例详解
2018/04/04 Python
python求最大值最小值方法总结
2019/06/25 Python
keras使用Sequence类调用大规模数据集进行训练的实现
2020/06/22 Python
CSS3制作ajax loader icon实现思路及代码
2013/08/25 HTML / CSS
用HTML5实现网站在windows8中贴靠的方法
2013/04/21 HTML / CSS
意大利拉斐尔时尚购物网:Raffaello Network(支持中文)
2018/11/09 全球购物
雅诗兰黛加拿大官网:Estee Lauder加拿大
2019/07/31 全球购物
同事吵架检讨书
2014/02/05 职场文书
个人求职自荐信范文
2014/06/20 职场文书
2014迎国庆演讲稿
2014/09/19 职场文书
初中作文评语
2014/12/25 职场文书
初中学生操行评语
2014/12/26 职场文书
教师节大会主持词
2015/07/06 职场文书
2016年教师寒假学习心得体会
2015/10/09 职场文书
如何在pycharm中快捷安装pip命令(如pygame)
2021/05/31 Python
浅谈MySql整型索引和字符串索引失效或隐式转换问题
2021/11/20 MySQL