700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > ajax contenttype详解_jQuery ajax contentType processData 笔记

ajax contenttype详解_jQuery ajax contentType processData 笔记

时间:2019-09-28 22:24:13

相关推荐

ajax contenttype详解_jQuery ajax contentType processData 笔记

contentType

contentType

默认:'application / x-www-form-urlencoded; charset = UTF-8'

类型:Boolean或者String

说明:将数据发送到服务器时,大多数情况直接使用默认值“application / x-www-form-urlencoded; charset = UTF-8”。从 jQuery 1.6开始,如果想将具体内容类型传递给 $ .ajax(),通过 contentType:false 来修改默认值。注意:W3C XMLHttpRequest 规范规定字符集是 UTF-8 ;指定另一个字符集不会强制浏览器更改编码。注意:对于跨域请求,将内容类型设置为除 application / x-www-form-urlencoded,multipart / form-data 或 text / plain 之外的任何内容将触发浏览器向服务器发送预检OPTIONS请求。

当设置了 contentType: false 以后

不设置 contentType

processData

默认:true

类型:Boolean

说明:默认情况下,以对象形式上传的数据,将被转换为查询字符串,来匹配contentType的默认值 “application / x-www-form-urlencoded” 。如果要发送 DOMDocument 或不需要转换成查询字符串的数据,请将此选项设置为false。

源码

s = jQuery.ajaxSetup( {}, options ),

// Convert data if not already a string

if ( s.data && s.processData && typeof s.data !== "string" ) {

s.data = jQuery.param( s.data, s.traditional );

}

复制代码

例子

jQuery.param 把 { width:1680, height:1050 } 参数对象序列化为 width=1680&height=1050 这样的字符串。

原生的 XMLHttpRequest 并没有这个参数,发送 XML 时通过 xhr.send(xmlDocument) 直接发送。

题外话

这里的 boundary 字符串是分界符,靠后的字符串是随机生成的,目的是使服务器正常解析文件。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。