アプリの動作をシミュレートするために、AJAX リクエストで jQuery Deferred オブジェクトを使用して簡単なデモをセットアップしました。
私の問題は、古い非遅延メソッドから切り替えて以来、成功のコールバックを取得できないことです。
コールバックのみfail()
が呼び出されます。誰かがコールバックを成功させるのを手伝ってくれますか? どこが間違っているのかわかりませんか?どんな助けにも感謝します
私のデモはこちらhttp://jsfiddle.net/jasondavis/y645yp4g/4/
私の古いAJAX呼び出しはこのようなものでした...
var ajax = $.ajax({
type: 'POST',
async: false,
contentType: 'application/json; charset=utf-8',
dataType: 'json',
url: '/gettask',
data: {
action: 'load-task-record',
task_id: taskId
},
success: function(data) {
// my success functionality here
}
});
Deferred オブジェクトを使用した新しい AJAX 呼び出し...
// Call function that execute AJAX request and returns it
var ajaxRequest = ajaxLoadTaskData();
ajaxRequest.done(function(response) {
if( response.success ) {
alert('AJAX request success');
}else{
// output the contents of response.errors
}
}).fail(function(response) {
// AJAX request failed
console.log('response', response);
alert('AJAX request failed');
}).always(function(response) {
});
// Run AJAX request and return Promise()
function ajaxLoadTaskData() {
return $.ajax({
type: 'POST',
async: false,
contentType: 'application/json; charset=utf-8',
dataType: 'json',
url: '/gettask',
data: {
action: 'load-task-record',
task_id: '1',
},
});
}
/gettask への AJAX 要求に対するモック AJAX 応答
// Mock AJAX response for AJAX request to /gettask
$.mockjax({
url: '/gettask',
contentType: 'text/json',
responseTime: 100,
response: function(settings) {
console.log('mockJax GET to /gettask :');
//console.log(settings);
if (settings.data.value == 'err') {
this.status = 500;
this.responseText = 'Validation error!';
} else {
var taskrecord = { 'name1': 'bar' };
this.responseText = taskrecord;
}
},
});