添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
还记得Promise对象吗?jQuery的jqXHR对象类似一个Promise对象,我们可以用链式写法来处理各种回调:
<script src="http://code.jquery.com/jquery-1.11.3.min.js"></script>
<textarea id="test-response-text" rows="5" style="width: 90%; margin: 15px 0;">
响应结果:
</textarea>
<script>
'use strict';
function ajaxLog(s) {
    var txt = $('#test-response-text');
    txt.val(txt.val() + '\n' + s);
$('#test-response-text').val('');
var jqxhr = $.ajax('/static/json/globalData.min.json', {
    dataType: 'json'
}).done(function (data) {
    ajaxLog('成功, 收到的数据: ' + JSON.stringify(data));
}).fail(function (xhr, status) {
    ajaxLog('失败: ' + xhr.status + ', 原因: ' + status);
}).always(function () {
    ajaxLog('请求完成: 无论成功或失败都会调用');
</script>
	对常用的AJAX操作,jQuery提供了一些辅助方法。由于GET请求最常见,所以jQuery提供了get()方法,可以这么写:
var jqxhr = $.get('/path/to/resource', {
    name: 'Bob Lee',
    check: 1
	第二个参数如果是object,jQuery自动把它变成query string然后加到URL后面,实际的URL是:
/path/to/resource?name=Bob%20Lee&check=1 
这样我们就不用关心如何用URL编码并构造一个query string了。 post()get()类似,但是传入的第二个参数默认被序列化为application/x-www-form-urlencoded
var jqxhr = $.post('/path/to/resource', {
    name: 'Bob Lee',
    check: 1
	实际构造的数据name=Bob%20Lee&check=1作为POST的body被发送。
	getJSON
	由于JSON用得越来越普遍,所以jQuery也提供了getJSON()方法来快速通过GET获取一个JSON对象:
var jqxhr = $.getJSON('/path/to/resource', {
    name: 'Bob Lee',
    check: 1
}).done(function (data) {
    // data已经被解析为JSON对象了
	jQuery的AJAX完全封装的是JavaScript的AJAX操作,所以它的安全限制和前面讲的用JavaScript写AJAX完全一样。
	如果需要使用JSONP,可以在ajax()中设置jsonp: 'callback',让jQuery实现JSONP跨域加载数据。
	关于跨域的设置请参考浏览器 - AJAX一节中CORS的设置。