jQuery默认为ajax statusCode

guy*_*oni 9 jquery default http-status-codes

据我所知,使用ajax处理错误结果的一种可能性如下:

$.ajax({
    url: someUrl,
    type: 'POST',
    success: function(data) {},
    error: function(jqXHR, exception) {
        if (jqXHR.status === 0) {
            alert('Not connect.\n Verify Network.');
        } else if (jqXHR.status == 404) {
            alert('Requested page not found. [404]');
        } else if (jqXHR.status == 500) {
            alert('Internal Server Error [500].');
        } else if (exception === 'parsererror') {
            alert('Requested JSON parse failed.');
        } else if (exception === 'timeout') {
            alert('Time out error.');
        } else if (exception === 'abort') {
            alert('Ajax request aborted.');
        } else {
            alert('Uncaught Error.\n' + jqXHR.responseText);
        }
    }
});
Run Code Online (Sandbox Code Playgroud)

或者使用statusCode以使其更具可读性:

$.ajax({
    url: someUrl,
    type: 'POST',
    statusCode: {
        200: function(data) {
                   :
                   :
             },
        401: function() {
                   :
                   :
             },
              :
              :
Run Code Online (Sandbox Code Playgroud)

我的问题是:
它是否可以使用statusCode并具有默认的后果?

Ric*_*her 17

不在statusCode参数中.但那是因为如果你想抓住一切,那就是更好(更精简)的方式:

complete: function(jqXHR, textStatus) {
    switch (jqXHR.status) {
        case 200:
            alert("200 received! yay!");
            break;
        case 404:
            alert("404 received! boo!");
            break;
        default:
            alert("I don't know what I just got but it ain't good!");
    }
}
Run Code Online (Sandbox Code Playgroud)

  • 十分感谢!真的干净简单.对于那些打算使用它的人,我想补充一点,为了从请求中获取json,你需要使用`data = jQuery.parseJSON(jqXHR.responseText);` (7认同)