東西越多,記不完,也記不住,筆記是最好的記憶了。ajax
回顧之前的ajax的寫法,簡單封裝一個ajax。app
//data = { // url: "url", // method: "post/get", // async: "true/false", // params: { key: value }, // success: fn, // error: fn //}; function Ajax(data) { //默認參數 var _data = { method: "post", async: "true", params: '', success: function (respose) { }, error: function (respose) { } } //重寫默認參數 for (var key in data) { _data[key] = data[key]; } //處理數據 if (_data.params) { var paramsArr = []; for (var pkey in _data.params) { paramsArr.push(pkey + '=' + _data.params[pkey]); } if (_data.method.toUpperCase() == 'GET') { _data.url += (_data.url.indexOf('?') > 0 ? '' : '?'); _data.url += paramsArr.join('&') + new Date().getTime();//避免cache; } else { _data.params = paramsArr.join('&'); } } //異步對象 var xhr = null; if (window.XMLHttpRequest) { xhr = new XMLHttpRequest(); } else if (window.ActiveXObject) { //IE xhr = new ActiveXObject("Microsoft.XMLHTTP"); } if (xhr == null) { alert("xhr對象實例化失敗!") return false; } //準備異步操做 xhr.open(_data.method, _data.url, _data.async); //設置回調函數 xhr.onreadystatechange = function () { console.log(this.readyState + " " + this.status); if (this.readyState == 4) { if (this.status == 200) { _data.success(this.responseText); } else { _data.error(this.responseText); } } }; if (_data.method.toUpperCase() === 'GET') { xhr.send(null); } else { //xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); xhr.setRequestHeader('Content-type', 'application/x-www-form-urlencoded'); xhr.send(_data.params); } }