摘要:
jQuery已經(jīng)成為項(xiàng)目中最常見的js庫,也是前端開發(fā)最喜歡使用的庫。下面是在項(xiàng)目中封裝了jQuery的Ajax,分享給大家。
代碼:
代碼如下:
// ajax 請求參數(shù)
var ajaxSettings = function(opt) {
var url = opt.url;
var href = location.href;
// 判斷是否跨域請求
var requestType = 'jsonp';
if (url.indexOf(location.host) > -1)
requestType = 'json';
requestType = opt.dataType || requestType;
// 是否異步請求
var async = (opt.async === undefined ? true : opt.async);
return {
url: url,
async: async,
type: opt.type || 'get',
dataType: requestType,
cache: false,
data: opt.data,
success: function(data, textStatus, xhr) {
/*
*如果dataType是json,怎判斷返回數(shù)據(jù)是否為json格式,如果不是進(jìn)行轉(zhuǎn)換
* 成功數(shù)據(jù)通用格式
* {
* "code": 200,
* "data": [],
* "success": true // 成功
* }
* 失敗返回的數(shù)據(jù)
* {
* "code": 200,
* "info": 'error',
* "success": false // 失敗
* }
*/
if((requestType === 'json' || requestType === "jsonp") && typeof(data) === "string") {
data = JSON.parse(data);
}
if(data.success) {
opt.success(data);
}
if(opt.error) {
opt.error(data);
}
},
error: function(xhr, status, handler) {
if (opt.error)
opt.error();
}
};
};
function unescapeEntity(str) {
var reg = /&(?:nbsp|#160|lt|#60|gt|62|amp|#38|quot|#34|cent|#162|pound|#163|yen|#165|euro|#8364|sect|#167|copy|#169|reg|#174|trade|#8482|times|#215|divide|#247);/g,
entity = {
' ' : ' ',
' ' : ' ',
'<' : '<',
'<' : '<',
'>' : '>',
'&62;' : '>',
'&' : '&',
'&' : '&',
'"' : '"',
'"' : '"',
'¢' : '¢',
'¢' : '¢',
'£' : '£',
'£' : '£',
'¥' : '¥',
'¥' : '¥',
'€' : '€',
'€' : '€',
'§' : '§',
'§' : '§',
'©' : '©',
'©' : '©',
'®' : '®',
'®' : '®',
'™' : '™',
'™' : '™',
'×' : '×',
'×' : '×',
'÷' : '÷',
'÷' : '÷'
};
if (str === null) {
return '';
}
str = str.toString();
return str.indexOf(';') < 0 ? str : str.replace(reg, function(chars) {
return entity[chars];
});
}
// 轉(zhuǎn)換html的實(shí)體
$.ajaxSetup({
global : true,
cache : false,
converters : {
'text json' : function(response){
return jQuery.parseJSON(unescapeEntity(response));
}
}
});
/*
*Ajax 請求權(quán)限異常
* 用戶權(quán)限錯誤跳轉(zhuǎn)登陸頁
* 404錯誤跳轉(zhuǎn)404頁面
*/
$(document).ajaxComplete(function(evt, req, settings){
if(req && req.responseJSON){
var json = req.responseJSON;
if(json.code === 403 && json.info === 'perm error' && !json.success){
window.location.href = location.protocol + '//' + location.hostname;
return;
}
if(json.code === 404 && !json.success) {
window.location.href = location.protocol + '//' + location.hostname + '/404.html';
}
}
});
/*
*Ajax 請求錯誤提示
*例如:500錯誤
*返回錯誤信息格式
*{
* code: 500,
* info: 系統(tǒng)發(fā)生異常
*}
*/
$(document).ajaxError(function(evt, req, settings){
if(req && (req.status === 200||req.status === 0)){ return false; }
var msg = '錯誤:';
if(req && req.responseJSON){
var json = req.responseJSON;
msg += json.code||'';
msg += json.info||'系統(tǒng)異常,請重試';
}else{
msg = '系統(tǒng)異常,請重試';
}
alert(msg);
});
小結(jié):
在執(zhí)行Ajax請求時只需要調(diào)用ajaxSettings函數(shù)即可,如下:
代碼如下:
$.ajax(ajaxSettings({
url: '',
data: ''
}))
以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。
更多信息請查看IT技術(shù)專欄