ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
# Ajax 请求 ## $.ajax ``` $.ajax(options) => XMLHttpRequest ``` 执行Ajax请求。它可以是本地资源,或者通过支持[HTTP access control](https://developer.mozilla.org/en/http_access_control)的浏览器 或者通过 [JSONP](http://json-p.org)来实现跨域。 选项: * `type`(默认: “GET”):请求方法 (“GET”, “POST”, or other) * `url` (默认: 当前地址):发送请求的地址 * `data` (默认:none):发送到服务器的数据;如果是GET请求,它会自动被作为参数拼接到url上。非String对象将通过 [$.param](#$.param) 得到序列化字符串。 * `processData` (默认: true): 对于非Get请求。是否自动将 `data` 转换为字符串。 * `contentType` (默认: “application/x-www-form-urlencoded”): 发送信息至服务器时内容编码类型。 (这也可以通过设置 `headers`)。通过设置 `false` 跳过设置默认值。 * `mimeType` (默认: none): 覆盖响应的MIME类型。 v1.1+ * `dataType` (默认: none):预期服务器返回的数据类型(“json”, “jsonp”, “xml”, “html”, or “text”) * `jsonp` (默认:“callback”): JSONP回调查询参数的名称 * `jsonpCallback` (默认: “jsonp{N}”): 全局JSONP回调函数的 字符串(或返回的一个函数)名。设置该项能启用浏览器的缓存。 v1.1+ * `timeout` (默认: `0`): 以毫秒为单位的请求超时时间, `0` 表示不超时。 * `headers`: Ajax请求中额外的HTTP信息头对象 * `async` (默认:true): 默认设置下,所有请求均为异步。如果需发送同步请求,请将此设置为 `false`。 * `global` (默认:true): 请求将触发全局Ajax事件处理程序,设置为 false 将不会触发全局 Ajax 事件。 * `context` (默认:window): 这个对象用于设置Ajax相关回调函数的上下文(this指向)。 * `traditional` (默认: false): 激活传统的方式通过[$.param](#$.param)来得到序列化的 `data`。 * `cache` (默认: true): 浏览器是否应该被允许缓存GET响应。从v1.1.4开始,当dataType选项为 `"script"` 或 `jsonp`时,默认为`false`。 * `xhrFields` (默认: none): 一个对象包含的属性被逐字复制到XMLHttpRequest的实例。 v1.1+ * `username` & `password` (默认: none): HTTP基本身份验证凭据。 v1.1+ 如果URL中含有 `=?`或者`dataType`是“jsonp”,这讲求将会通过注入一个 `&lt;script&gt;`标签来代替使用 XMLHttpRequest (查看 [JSONP](http://json-p.org))。此时 `contentType`, `dataType`, `headers`有限制,`async` 不被支持。 ### Ajax 回调函数 你可以指定以下的回调函数,他们将按给定的顺序执行: 1. `beforeSend(xhr, settings)`:请求发出前调用,它接收xhr对象和settings作为参数对象。如果它返回 `false` ,请求将被取消。 2. `success(data, status, xhr)`:请求成功之后调用。传入返回后的数据,以及包含成功代码的字符串。 3. `error(xhr, errorType, error)`:请求出错时调用。 (超时,解析错误,或者状态码不在HTTP 2xx)。 4. `complete(xhr, status)`:请求完成时调用,无论请求失败或成功。 ### Promise 回调接口 v1.1+ 如果可选的“callbacks” 和 “deferred” 模块被加载,从`$.ajax()`返回的XHR对象实现了promise接口链式的回调: ``` xhr.done(function(data, status, xhr){ ... }) xhr.fail(function(xhr, errorType, error){ ... }) xhr.always(function(){ ... }) xhr.then(function(){ ... }) ``` 这些方法取代了 `success`, `error`, 和 `complete` 回调选项. ### Ajax 事件 当`global: true`时。在Ajax请求生命周期内,以下这些事件将被触发。 1. `ajaxStart` _(global)_:如果没有其他Ajax请求当前活跃将会被触发。 2. `ajaxBeforeSend` (data: xhr, options):再发送请求前,可以被取消。 3. `ajaxSend` (data: xhr, options):像 `ajaxBeforeSend`,但不能取消。 4. `ajaxSuccess` (data: xhr, options, data):当返回成功时。 5. `ajaxError` (data: xhr, options, error):当有错误时。 6. `ajaxComplete` (data: xhr, options):请求已经完成后,无论请求是成功或者失败。 7. `ajaxStop` _(global)_:如果这是最后一个活跃着的Ajax请求,将会被触发。 默认情况下,Ajax事件在document对象上触发。然而,如果请求的 `context` 是一个DOM节点,该事件会在此节点上触发然后再DOM中冒泡。唯一的例外是 `ajaxStart` & `ajaxStop`这两个全局事件。 ``` $(document).on('ajaxBeforeSend', function(e, xhr, options){ // This gets fired for every Ajax request performed on the page. // The xhr object and $.ajax() options are available for editing. // Return false to cancel this request. }) $.ajax({ type: 'GET', url: '/projects', // data to be added to query string: data: { name: 'Zepto.js' }, // type of data we are expecting in return: dataType: 'json', timeout: 300, context: $('body'), success: function(data){ // Supposing this JSON payload was received: // {"project": {"id": 42, "html": "<div>..." }} // append the HTML to context object. this.append(data.project.html) }, error: function(xhr, type){ alert('Ajax error!') } }) // post a JSON payload: $.ajax({ type: 'POST', url: '/projects', // post payload: data: JSON.stringify({ name: 'Zepto.js' }), contentType: 'application/json' }) ``` ## $.ajaxJSONP 不推荐, 使用 [$.ajax](#$.ajax) 代替。 ``` $.ajaxJSONP(options) => mock XMLHttpRequest ``` 执行JSONP跨域获取数据。 此方法相对 [$.ajax](#$.ajax) 没有优势,建议不要使用。 ## $.ajaxSettings 一个包含Ajax请求的默认设置的对象。大部分的设置在 [$.ajax](#$.ajax)中已经描述。以下设置为全局非常有用: * `timeout` (默认: `0`):对Ajax请求设置一个非零的值指定一个默认的超时时间,以毫秒为单位。 * `global` (默认: true):设置为false。以防止触发Ajax事件。 * `xhr` (默认:XMLHttpRequest factory):设置为一个函数,它返回XMLHttpRequest实例(或一个兼容的对象) * `accepts`: 从服务器请求的MIME类型,指定`dataType`值: * script: “text/javascript, application/javascript” * json: “application/json” * xml: “application/xml, text/xml” * html: “text/html” * text: “text/plain” ## $.get ``` $.get(url, function(data, status, xhr){ ... }) => XMLHttpRequest $.get(url, [data], [function(data, status, xhr){ ... }], [dataType]) => XMLHttpRequest v1.0+ ``` 执行一个Ajax GET请求。这是一个 [$.ajax](#$.ajax)的简写方式。 ``` $.get('/whatevs.html', function(response){ $(document.body).append(response) }) ``` ## $.getJSON ``` $.getJSON(url, function(data, status, xhr){ ... }) => XMLHttpRequest $.getJSON(url, [data], function(data, status, xhr){ ... }) => XMLHttpRequest v1.0+ ``` 通过 Ajax GET请求获取JSON数据。这是一个 [$.ajax](#$.ajax) 的简写方式。 ``` $.getJSON('/awesome.json', function(data){ console.log(data) }) // fetch data from another domain with JSONP $.getJSON('//example.com/awesome.json?callback=?', function(remoteData){ console.log(remoteData) }) ``` ## $.param ``` $.param(object, [shallow]) => string $.param(array) => string ``` 序列化一个对象,在Ajax请求中提交的数据使用URL编码的查询字符串表示形式。如果shallow设置为true。嵌套对象不会被序列化,嵌套数组的值不会使用放括号在他们的key上。 如果任何对象的某个属性值是一个函数,而不是一个字符串,该函数将被调用并且返回值后才会被序列化。 此外,还接受 [serializeArray](#serializeArray)格式的数组,其中每个项都有 “name” 和 “value”属性。 ``` $.param({ foo: { one: 1, two: 2 }}) //=> "foo[one]=1&foo[two]=2)" $.param({ ids: [1,2,3] }) //=> "ids[]=1&ids[]=2&ids[]=3" $.param({ ids: [1,2,3] }, true) //=> "ids=1&ids=2&ids=3" $.param({ foo: 'bar', nested: { will: 'not be ignored' }}) //=> "foo=bar&nested[will]=not+be+ignored" $.param({ foo: 'bar', nested: { will: 'be ignored' }}, true) //=> "foo=bar&nested=[object+Object]" $.param({ id: function(){ return 1 + 2 } }) //=> "id=3" ``` ## $.post ``` $.post(url, [data], function(data, status, xhr){ ... }, [dataType]) => XMLHttpRequest ``` 执行Ajax POST请求。这是一个 [$.ajax](#$.ajax) 的简写方式。 ``` $.post('/create', { sample: 'payload' }, function(response){ // process response }) ``` `data` 参数可以是一个字符串: ``` $.post('/create', $('#some_form').serialize(), function(response){ // ... }) ``` ## load ``` load(url, function(data, status, xhr){ ... }) => self ``` 通过GET Ajax载入远程 HTML 内容代码并插入至 当前的集合 中。另外,一个css选择器可以在url中指定,像这样,可以使用匹配selector选择器的HTML内容来更新集合。 ``` $('#some_element').load('/foo.html #bar') ``` 如果没有给定CSS选择器,将使用完整的返回文本。 请注意,在没有选择器的情况下,任何javascript块都会执行。如果带上选择器,匹配选择器内的script将会被删除。