/** * 模擬ajax的 script請求 * @param {[type]} options [description] * @return {[type]} [description] */ function createAjax(options) { if (typeof url === "object") { options = url; url = undefined; } options = options || {}; /** * 參數 * jQuery.ajaxSetup 是默認參數 * @type {[type]} */ var s = jQuery.ajaxSetup({}, options); // Deferreds // 異步機制 var deferred = jQuery.Deferred(); var completeDeferred = jQuery.Callbacks("once memory"); /** * 實際返回的ajax對象 * @type {Object} */ var jqXHR = {} // 把jqXHR對象轉化promise對象,幷加入complete、success、error方法 deferred.promise(jqXHR).complete = completeDeferred.add; //別名 jqXHR.success = jqXHR.done; jqXHR.error = jqXHR.fail; // 增長回調隊列 // complete: function() { // console.log('局部事件complete') // }, // error: function() { // console.log('局部事件error請求失敗時調用此函數') // }, // success: function() { // console.log('局部事件success') // } for (i in { success: 1, error: 1, complete: 1 }) { jqXHR[i](s[i]); } function send(_, complete) { var script = jQuery("<script>").prop({ async: true, charset: s.scriptCharset, src: s.url }).on( "load error", callback = function(evt) { script.remove(); callback = null; if (evt) { complete(evt.type === "error" ? 404 : 200, evt.type); } } ); document.head.appendChild(script[0]); } function done(status, nativeStatusText, responses, headers) { var isSuccess = status >= 200 && status < 300 || status === 304; var success = jqXHR.success; var error = jqXHR.error; if (isSuccess) { deferred.resolveWith(document, [success, jqXHR]); } else { deferred.rejectWith(document, [jqXHR, error]); } } //發送請求 send({ Accept: "text/javascript, application/javascript, application/ecmascri" }, done); return jqXHR; } function show(data){ $('body').append('<li>'+ data +'</li>'); } //執行一個異步的HTTP(Ajax)的請求。 var ajax = createAjax({ url: 'http://code.jquery.com/jquery-latest.js', dataType: 'script', //請求完成後回調函數 (請求success 和 error以後均調用) complete: function() { show('局部事件complete') }, error: function() { show('局部事件error請求失敗時調用此函數') }, success: function() { show('局部事件success') } }) ajax.done(function() { show('deferred done') }).fail(function() { show('deferred fail') }).always(function() { show('deferred lways') })