如何拦截或修改原生ajax请求

前端之家收集整理的这篇文章主要介绍了如何拦截或修改原生ajax请求前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

jQuery已经实现了各种 ajax 事件,如 beforeSend 等,但原生的XMLHttpRequest 并没有这种事件。在没有用 jQuery的情况下,如果想修改 ajax 请求,得做一些特殊的处理。以下是我处理的方法

XMLHttpRequest.prototype._open=XMLHttpRequest.prototype.open;
XMLHttpRequest.prototype.open=function(method,url,async){
//用对象便于修改参数
varoptions={
method:method,url:url,async:async
};
if('function'===typeofwindow.beforeXMLHttpRequestSend){
if(!window.beforeXMLHttpRequestSend(this,options)){
return;
}
}
this._open(options.method,options.url,options.async);
};


window.beforeXMLHttpRequestSend=function(xhr,options){
//重置参数
options.url='reseturl';
options.method='PUT';
options.async=false;

//禁止发送请求
//returnfalse;

//发送请求
returntrue;
};
原文链接:https://www.f2er.com/ajax/163617.html

猜你在找的Ajax相关文章