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

用过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。

示例如下:

?


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

31

32

33

34

35

36

37

38

39

40

41

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

     
Vue2.0从入门到项目实战:电商项目 
VueJs基础入门详解:45节课
最新Web界面库vue.js视频教程
vue.js实战项目:美团外卖平台  ...2
智能社vue.js精讲视频教程
麦子学院Vuejs详解31课 
Bootstrap入门实战网站后台管理教程 
jQuery高级进阶视频教程附讲义源码 10课
JQuery快速学习视频教程附讲义源码 10课
web前端综合演练公开课视频教程附源码讲义 22课
AJAX跨域解决方案:JSONP讲义源码 5课
AJAX入门AJAX原理和封装附讲义源码 7课
妙味课堂web前端HTML5入门高清视频附源码 38课
妙味课堂web前端JavaScript正则表达式高清视频附源码 11课
妙味课堂web前端CSS3.0入门高清视频附源码 22课
妙味课堂VIP全套视频前端初窥篇web前端开发入门到精通高清附源码
妙味课堂VIP课程移动前端仿ios滑屏切换开发案例高清视频附源码 4课
妙味课堂VIP课程JavaScript算法与数据结构高清视频教程附源码 10课
妙味课堂VIP课程HTML5微信H5游戏打怪游戏开发高清视频教程附源码 21课
妙味课堂XHTML+CSS2整站布局设计视频教程高清附源码 12课

原文地址:https://www.cnblogs.com/xanthedsf/p/10163993.html

时间: 2024-08-02 12:08:09

使用jquery Ajax实现上传附件功能的相关文章

兼容ie的jquery ajax文件上传

Ajax文件上传插件很多,但兼容性各不一样,许多是对ie不兼容的,另外项目中是要求将网页内容嵌入到桌面端应用的,这样就不允许带flash的上传插件了,如:jquery uploadify...悲剧 对于Ajax文件上传,大体是有: 1.创建一个input type="file" 的文件上传按钮,根据其id监听绑定其change事件,在事件中用jquery创建一个iframe,嵌入添加隐藏form,同时创建input type="file",id相同的文件上传按钮,并

jquery ajax实现上传文件代码,带进度条

原文:jquery ajax实现上传文件代码,带进度条 源代码下载地址:http://www.zuidaima.com/share/1550463291116544.htm ajax上传文件代码,带进度条的. 首页 http://localhost:端口/项目名/common/test.htm 上传中 标签: jquery ajax 上传 进度条话题: Web开发 前端技术 jquery ajax实现上传文件代码,带进度条

使用HttpRequest.Files 获取上传文件,实现上传附件功能

使用HttpRequest.Files 获取上传文件,实现上传附件功能,不同浏览器会有差异: 获得在 Google 浏览器上传后得到的 HttpRequest.Files  (客户端上载文件的集合) 单个文件查看:对应的FileName 是上传文件的原始文件名:例:开发管理手册2017版.docx 获取IE浏览器上传后HttpRequest.Files: 单个文件查看:对应的FileName 是上传文件 带路径的文件名 例:C:\\Users\\XXX\\Desktop\\开发管理手册2017版

ASP.NET 异步Web API + jQuery Ajax 文件上传代码小析

该示例中实际上应用了 jquery ajax(web client) + async web api 双异步. jquery ajax post 1 $.ajax({ 2 type: "POST", 3 url: "/api/FileUpload", 4 contentType: false, 5 processData: false, 6 data: data, 7 success: function (results) { 8 ShowUploadControl

Struts2 使用Jquery+ajax 文件上传

话不多说 直接上代码 前台js: 1 var formData = new FormData(); 2 formData.append("file1",$("#file1")[0].files[0]);//第一个file1代表后台文件属性名,第二个file1表示html中input的id 3 $.ajax({ 4 type:"post", 5 url:"ajax/uploadFile", 6 data:formData, 7

struts2+jquery+ajax实现上传&amp;&amp;校验实例

一直以为ajax不能做上传,直到最近看了一些文章.代码和相关配置如下: js代码: <script> //ajax 无刷新上传文件 function ajaxFileUpload() { //判断是否选择文件 if($("#uploadFile").val() == null || $("#uploadFile").val()==""){ alert("请选择需要上传的文件!"); return; } //判断后缀

jQuery ajax 文件上传

html javascript var dat = new FormData() dat.append('prefix', $(':input[name=prefix]').val()) dat.append('file', $(':input[name=upfile]')[0].files[0]) var req = $.ajax({ url: $('#upload').attr('action'), data: dat, dataType: 'json', type: 'POST', con

jquery easyui filebox 上传附件 + asp.net后台

form必须加这个属性enctype="multipart/form-data",否则后台获取不到文件 1 <script> 2 function uploadFiles() { 3 $('#fm').form('submit', { 4 url: 'Upload.aspx?fjssmk=Xmgl', 5 success: function (result) { 6 var result = eval('(' + result + ')'); 7 //可以写一些提示的代码等

怎样解决asp.net.mvc上传附件超过长度问题?

最近,在做一个上传附件功能,但是文件超过4M,就报上传的文件超过长度问题 如何解决这个问题呢?这里我找了一下资料,了解一下问题所在,有3种解决方法 方案一:在所在项目的web.config配置文件中,修改maxRequestLength的值 方案二:在.net framework的安装目录下的machine.config配置文件,修改maxRequestLength的值 方案三:修改IIS服务的上传文件大小的限制 方案一: 1.修改web.config文件,改变这个maxRequestLengt