码迷,mamicode.com
首页 > Web开发 > 详细

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

时间:2015-03-30 23:16:42      阅读:861      评论: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
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!