6

現在、スクリプトを jquery に変更しています。これは私の古いJavaScriptです:

var request = (window.XMLHttpRequest) ? new XMLHttpRequest() : (window.ActiveXObject ? new window.ActiveXObject("Microsoft.XMLHTTP") : false);
request.open("GET", url, true);
request.onreadystatechange = updatePage;
request.send(null);

function updatePage() {
        if (request.readyState == 4) {
                if (request.status == 200) {
                    var response = request.responseText;
                    doSomething();
                } else if (request.status == 304) {
                    doSomethingElse();
                } else {
                }
        }
}

これをjquery-ajaxに変更したい:

request = $.ajax({
    type: "GET",
    url: url,
    data: data,
    success: updatePage
});

古いスクリプトで行ったように、リクエストによって返されたステータス コード (および responseText) をテストするにはどうすればよいですか?

4

2 に答える 2

20

これを試して:

request = $.ajax({
    type: "GET",
    url: url,
    data: data,
    statusCode: {
      200: function() {
        doSomething();
       },
      304:function(){
        doSomethingElse();
       }
     }
});

また:

request = $.ajax({
    type: "GET",
    url: url,
    data: data,
    complete: function(e, xhr, settings){
       if(e.status === 200){

       }else if(e.status === 304){

       }else{

       }
    }
});
于 2012-10-06T12:07:39.033 に答える
1

このリクエストをボタンクリックなどのイベントにバインドする必要があります

$('#btn').click({function(){
$.ajax({
    type: "GET",
    url: url,
    data: data,
    success: updatePage
});
});

jQuery ajaxには成功後のコードを実行するのに役立つ成功コールバックがあるため、このリクエストを変数に対して保持する必要はありません

于 2012-10-06T12:09:29.900 に答える