https://juejin.im/post/59e85eebf265da430d571f89
;function ajax(params) {
params = params || {};
params.data = params.data || {};
// 判斷是ajax請(qǐng)求還是jsonp請(qǐng)求
var json = params.jsonp? jsonp(params) : json(params);
function formatParams(data) {
var arr = [];
for (var name in data) {
// encodeURIComponent()
arr.push(encodeURIComponent(name) + '=' + encodeURIComponent(data[name]));
};
// 添加一個(gè)隨機(jī)數(shù)參數(shù) 防止緩存
arr.push('v='+random());
return arr.join('&');
}
function json(params) {
params.type = (params.type || 'GET').toUpperCase();
params.data = formatParams(params.data);
var xhr = null;
if(window.XMLHttpRequest) {
xhr = new XMLHttpRequest();
} else {
xhr = new ActiveXObject('Microsoft.XMLHTTP');
};
xhr.onreadystatechange = function() {
/*
* 0:為初始化耗绿。尚未調(diào)用open()方法欺劳。
* 1:?jiǎn)?dòng)尔破。已經(jīng)調(diào)用open()方法键科。但尚未調(diào)用send()方法。
* 2:發(fā)送挠锥。已經(jīng)調(diào)用send()方法众羡。但尚未接受到響應(yīng)。
* 3:接受蓖租。已經(jīng)接收到部分響應(yīng)數(shù)據(jù)粱侣。
* 4:完成。已經(jīng)接收到全部響應(yīng)數(shù)據(jù)蓖宦,并且可以在客戶端使用齐婴。
*/
if(xhr.readyState == 4) {
var status = xhr.status;
if (status >= 200 && status < 300) {
var response = "";
var type = xhr.getResponseHeader('Content-type');
if (type.indexOf('xml') !== -1 && xhr.responseXML) {
response = xhr.responseXML; // document對(duì)象響應(yīng)
} else if (type === 'application/json') {
response = JSON.parse(xhr.responseText);
} else {
response = xhr.responseText; // 字符串響應(yīng)
}
}
params.success && params.success(response);
} else {
params.error && params.error(status);
}
};
};
function jsonp(params) {
var callbackName = params.jsonp;
var head = document.getElementsByTagName('head')[0];
// 設(shè)置傳遞給后臺(tái)的回調(diào)參數(shù)名
params.data['callback'] = callbackName;
var data = formatParams(params.data);
var script = document.createElement('script');
head.appendChild(script);
// 創(chuàng)建jsonp回調(diào)函數(shù)
window[callbackName] = function (json) {
head.removeChild(script);
clearTimeout(script.timer);
window[callbackName] = null;
params.success && params.success(json);
};
script.src = params.url + '?' + data;
if(params.time) {
script.timer = setTimeout(function(){
window[callbackName] = null;
head.removeChild(script);
params.error && params.error({
message: '超時(shí)'
});
}, time);
}
};
if (params.type == 'GET') {
xhr.open(params.type, params.url + '?' + params.data, true);
xhr.send(null);
} else {
xhr.open(params.type, params.url, true);
// 設(shè)置提交時(shí)的內(nèi)容類型
xhr.setRequestHeader('Content-type', 'application/x-ww-form-urlencoded; charset=UTF-8');
xhr.send(params.data);
}
}
ajax({
url: 'text.php',
type: 'POST',
data: {'b': '異步請(qǐng)求'},
success: function(res){
console.log(JSON.parse(res));
}
error: function(error){}
});
ajax({
url: 'test', // 請(qǐng)求地址
jsonp: 'jsonpCallback', // 采用jsonp請(qǐng)求,且回調(diào)函數(shù)名為"jsonpCallbak"稠茂,可以設(shè)置為合法的字符串
data: {'b': '異步請(qǐng)求'}, // 傳輸數(shù)據(jù)
success:function(res){ // 請(qǐng)求成功的回調(diào)函數(shù)
console.log(res);
},
error: function(error) {} // 請(qǐng)求失敗的回調(diào)函數(shù)
});