Метод POST, сообщение об ошибке состояния (отменено)
У меня есть следующий код, который дает мнеMethod POST, Status (canceled)
сообщение об ошибке:
$(document).ready(function() {
var xhr = false;
get_default();
$('#txt1').keyup( function() {
if(xhr && xhr.readyState != 4){
alert("abort");
xhr.abort();
}
if ($("#txt1").val().length >= 2) {
get_data( $("#txt1").val() );
} else {
get_default();
}
});
function get_data( phrase ) {
xhr = $.ajax({
type: 'POST',
url: 'http://intranet/webservices.asmx/GetData',
data: '{phrase: "' + phrase + '"}',
contentType: 'application/json; charset=utf-8',
dataType: 'json',
success: function( results ) {
$("#div1").empty();
if( results.d[0] ) {
$.each( results.d, function( index, result ) {
$("#div1").append( result.Col1 + ' ' + result.Col2 + '<br />' );
});
} else {
alert( "no data available message goes here" );
}
},
error: function(xhr, status, error) {
var err = eval("(" + xhr.responseText + ")");
alert(err.Message) ;
}
});
}
function get_default() {
$('#div1').empty().append("default content goes here.");
}
});
Код фактически работает до тех пор, пока завершается каждый ajax-запрос, но если я быстро наберу вtxt1
, то есть введите следующий символ до завершения предыдущего запроса, я получаю сообщение об ошибкеMethod POST, Status (canceled)
.
Кто-нибудь знает, почему это происходит и как исправить ошибку?