首页 > Web开发 > 详细

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

时间:2015-03-30 23:16:22      阅读:600      评论:0      收藏:0      [点我收藏+]

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

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


window.beforeXMLHttpRequestSend = function(xhr, options) {
    //重置参数
    options.url == ‘reset url‘;
    options.method = ‘PUT‘;
    options.async = false;
    
    //禁止发送请求
    //return false;
    
    //发送请求
    return true;    
};



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

原文:http://my.oschina.net/lovebing/blog/393784

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!