如果您使用 jQuery,这$.ajaxSuccess
是一个不错的选择,但这里有一个更通用的选项,它将拦截来自所有框架的 XHR 调用(我已经用 ExtJS 和 jQuery 对其进行了测试 - 即使同时加载多个框架它也应该工作)。它已经过测试,可与 IE8、Chrome 和 Firefox 一起使用。
(function(XHR) {
"use strict";
var open = XHR.prototype.open;
var send = XHR.prototype.send;
XHR.prototype.open = function(method, url, async, user, pass) {
this._url = url;
open.call(this, method, url, async, user, pass);
};
XHR.prototype.send = function(data) {
var self = this;
var oldOnReadyStateChange;
var url = this._url;
function onReadyStateChange() {
if(self.readyState == 4 /* complete */) {
/* This is where you can put code that you want to execute post-complete*/
/* URL is kept in this._url */
}
if(oldOnReadyStateChange) {
oldOnReadyStateChange();
}
}
/* Set xhr.noIntercept to true to disable the interceptor for a particular call */
if(!this.noIntercept) {
if(this.addEventListener) {
this.addEventListener("readystatechange", onReadyStateChange, false);
} else {
oldOnReadyStateChange = this.onreadystatechange;
this.onreadystatechange = onReadyStateChange;
}
}
send.call(this, data);
}
})(XMLHttpRequest);
我在 github 上发布了一个更具体的示例,它拦截 AJAX 调用并将 AJAX 调用持续时间发布回服务器进行统计分析。