javascript – 如何抓住jQuery AJAX错误?

栏目: jQuery · 发布时间: 7年前

内容简介:http://stackoverflow.com/questions/18864734/how-can-i-catch-jquery-ajax-errors

当一个AJAX请求被提交到一个站点时,服务器端的错误很容易用jQuery承诺方法处理. .done(),.fail()等.但是,对于某些请求(例如,到无效站点或不接受跨源请求的请求),在进行呼叫时立即发生异常.以下是控制台中一个错误的示例:

XMLHttpRequest cannot load http://someotherserver/api/blahblah . Origin

http://localhost:52625 is not allowed by Access-Control-Allow-Origin.

是的,我知道CORS …这不是问题.我正在做的是尝试网络api调用来测试服务器IP /名称是否正确

我知道jQuery请求语法中的错误选项:

$.ajax({
    url: remoteURL,
    type: 'GET',
    error: function (err) {
        console.log("AJAX error in request: " + JSON.stringify(err, null, 2));
    }
}).etc.etc.

错误在这里处理,但异常仍记录在控制台中.将这些包装在try-catch块中似乎是合理的,但这似乎没有帮助.

我发现了 this question ,但解决方案涉及到黑客jQuery代码.当然有更好的方法来捕捉这些错误,而不是堵塞控制台日志?

尝试这个:

$.ajax({
    url: remoteURL,
    type: 'GET',
    error: function (err) {
        console.log("AJAX error in request: " + JSON.stringify(err, null, 2));
    }
}).always(function(jqXHR, textStatus) {
    if (textStatus != "success") {
        alert("Error: " + jqXHR.statusText);
    }
});

XHR听众:

$.ajax({
    url: remoteURL,
    type: 'GET',
    xhr: function(){
        var xhr = new window.XMLHttpRequest();
        xhr.addEventListener("error", function(evt){
            alert("an error occured");
        }, false);
        xhr.addEventListener("abort", function(){
            alert("cancelled");
        }, false);

        return xhr;
    },
    error: function (err) {
        console.log("AJAX error in request: " + JSON.stringify(err, null, 2));
    }
});

http://stackoverflow.com/questions/18864734/how-can-i-catch-jquery-ajax-errors


以上所述就是小编给大家介绍的《javascript – 如何抓住jQuery AJAX错误?》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

HTML 5实战

HTML 5实战

陶国荣 / 机械工业出版社 / 2011-11 / 59.00元

陶国荣编著的《HTML5实战》是一本系统而全面的HTML 5教程,根据HTML 5标准的最新草案,系统地对HTML 5的所有重要知识点进行了全面的讲解。在写作方式上,本书以一种开创性的方式使理论与实践达到极好的平衡,不仅对理论知识进行了清晰而透彻的阐述,而且根据读者理解这些知识的需要,精心设计了106个完整(每个案例分为功能描述、实现代码、效果展示和代码分析4个部分)的实战案例,旨在帮助读者通过实......一起来看看 《HTML 5实战》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

MD5 加密
MD5 加密

MD5 加密工具