版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_28483283/article/details/79079079
.ajaxComplete()的使用以及详解
先上一段代码:
$(document).ajaxComplete(function(event,request, settings){
var EwdFlag =request.getResponseHeader("EwdFlag")
if(EwdFlag=="noSession"){
window.top.location.href = "../index.jsp";
}
if(EwdFlag=='noRoute'){
var noRouteUrl=request.getResponseHeader("noRouteUrl");
console.log(noRouteUrl+"路径不存在")
window.location="../error/noRoute.jsp?url="+ noRouteUrl;
}
if(EwdFlag=='noPower'){
var noPowerUrl=request.getResponseHeader("noPowerUrl");
console.log(noPowerUrl+"没有权限");
window.location="../error/noRoute.jsp?url="+ noPowerUrl;
}
});
解析:上面这段代码位于common.js,每一个页面都会引入,而
当然 ajax还有其他常用并且与之类似的函数
三个参数的作用
function(event,request, settings)
event - 包含 event 对象
xhr - 包含 XMLHttpRequest 对象
options - 包含 AJAX 请求中使用的选项
鄙人使用的方式在拦截器中判断该用户是否用该权限,如果没有则
((HttpServletResponse) resp).setHeader("EwdFlag", "noRoute");
然后再ajax执行完以后执行
if(EwdFlag=='noRoute'){
var noRouteUrl=request.getResponseHeader("noRouteUrl");
console.log(noRouteUrl+"路径不存在")
window.location="../error/noRoute.jsp?url="+ noRouteUrl;
}
然后就会跳转到没有权限提示的页面,同理。验证当前session是否过期也是用此方法,但是此方法仅仅适用于ajax请求以后,执行
还有一点:
$(document).ajaxComplete是所有的ajax执行完毕以后都会执行此方法