为什么我的AJAX调用成功函数没有触发java脚本警报?

时间:2013-08-15 18:35:13

标签: javascript jquery ajax

$.ajax({
   url: '../api/notifications/deleteNotification?userId=' + userId + '&notificationId=' + notificationId,
   type: 'DELETE',
   success: function()
   {
       CreateNotificationTree(userId);
       alert('Delete successful.');
   },
   failure: function()
   {
       alert('Delete failed.');
   }
});

在DOES上面的ajax调用的成功函数内部的函数CreateNotificationTree(userId);触发。但是,警报并未触发。有人知道为什么吗?我也试过使用多个浏览器。

编辑 - 发现我在执行AJAX调用时遇到此错误:

Uncaught TypeError: Cannot read property 'uid' of undefined kendo.web.min.js:23
(anonymous function) kendo.web.min.js:23
p.extend.each jquery.min.js:2
p.fn.p.each jquery.min.js:2
g.extend._attachUids kendo.web.min.js:23
g.extend.init kendo.web.min.js:22
(anonymous function) kendo.web.min.js:9
p.extend.each jquery.min.js:2
p.fn.p.each jquery.min.js:2
$.fn.(anonymous function) kendo.web.min.js:9
CreateNotificationTree NotificationsTreeView.js:17
(anonymous function) NotificationsTreeView.js:60
k jquery.min.js:2
l.fireWith jquery.min.js:2
y jquery.min.js:2
d

1 个答案:

答案 0 :(得分:5)

将错误记录到您的控制台。

如果ajax失败方法,则您看不到警告,因为jQuery无法识别failure方法。

使用 error 回调记录错误。

同样使用console.log代替alert,这会令人烦恼并停止执行流程

failure: function(){
   alert('Delete failed.');
}

应该是

error: function(){
   alert('Delete failed.');
}

使用donefail代替successerror回调,因为后者已弃用版本1.8

$.ajax({
    url: '../api/notifications/deleteNotification?userId=' 
               + userId + '&notificationId=' + notificationId,
    type: 'DELETE'
}).done(function () {
    CreateNotificationTree(userId);
    console.log('Delete successful.');
}).fail(function (jqXHR, status, error) {
    console.log("Error : " + error);
});

使用传递给回调的arguments,您将能够查明错误。