项目中经常会遇到需要统一设置 ajax请求的预处理 和 需要统一处理ajax返回的需求
比如登录时需要 在头部添加token(X-Auth-Token)
请求完需要判断code为已退出token失效(3001)和权限不足(3002)的情况
之前习惯使用 jQuery.ajaxSetup() 统一设置ajax参数,但是官方不建议使用,而且这种方式确实不够灵活
jQuery.ajaxSetup() | jQuery API Documentation
Description: Set default values for future Ajax requests. Its use is not recommended.
后来看到 ajax的全局事件的支持,发现这个比较适合
http://api.jquery.com/category/ajax/global-ajax-event-handlers/
if(window.jQuery){
// ajax预处理
jQuery(document).bind("ajaxSend", function(event, request, settings){
var token = getUserToken();
//config_contextPath 为需要设置token的 全局host,严格判断防止 token发送到其他站点被盗取
if(token && config_contextPath && settings.url && settings.url.indexOf(config_contextPath) === 0){
var headers = settings.headers || {};
headers["X-Auth-Token"] = token;
request.setRequestHeader("X-Auth-Token", token);
settings.headers = headers;
}
})
// 后置处理
.bind("ajaxComplete", function(event, xhr, settings){
if(config_contextPath && settings.url && settings.url.indexOf(config_contextPath) === 0 && (settings.dataType === 'JSON' || settings.dataType === 'json')){
if(xhr.status == 200 && xhr.responseText){
try{
var reObj = JSON.parse(xhr.responseText);
//特殊code 没有权限 和token失效
if(reObj && (reObj.code==3001 || reObj.code==3002 )){
window.setTimeout(function () {
if($(".layui-layer-dialog.layui-layer-msg:visible").length < 1){
layer.alert(reObj.message, {icon: 2}, function () {
if(reObj.code==3001){
var topWindow = parent ? (parent.parent ? (parent.parent.parent ? parent.parent.parent : parent.parent) : parent) : window;
topWindow.location.href='/login.html';
}
});
}
}, 500);
}
}catch (e){console.error(e)}
}
}
});
}