AJAX成功失败回调无法正常工作

时间:2016-12-07 19:07:26

标签: javascript jquery ajax callback

我有一张桌子,我有一个删除按钮。基本上我想要做的是当我点击删除按钮时,它会向我们的服务器发送DELETE请求并在db上更新。如果成功,它将从表中删除该行。

Config.js

var SiteConfigProxy = function () {
"use strict";

var getSiteConfig = Config.apiUrl + "/configs/site/{siteId}";
var addDevice = Config.apiUrl + "/configs/device/{deviceId}";

var delete1 = function (url, data, done, fail){
    $.ajax({
        type: "DELETE",
        url: url,
        data: JSON.stringify(data),
        contentType: "application/json; charset=utf-8",
        dataType: "json",
        success: function (data) {
            if (typeof (done) === 'function') done(data);
        },
        failure: function (data) {
            if (typeof (fail) === 'function') fail(data);
        }
    });
};

return {
    deleteDeviceConfig: function (deviceId, data, done, fail){
        delete1(addDevice.replace("{deviceId}", deviceId), data, done, fail);
    }
};
} ();

siteconfig.js

        configTable.on("click", ".delete", function (event) {
        event.preventDefault();
        if (confirm("Are you sure to delete this row?")) {
            var tableRow = $(this).parents("tr")[0];
            var data = {
                siteId: tableData.fnGetData(tableRow)[1],
                hostname: tableData.fnGetData(tableRow)[2]
            };

            SiteConfigProxy.deleteDeviceConfig(tableData.fnGetData(tableRow)[0], data,
                function(data){
                    tableData.fnDeleteRow(tableRow);
                    console.log("delete succeeded");
                },
                function(data){
                    console.log("delete failed");
                }
            );
        }
    });

现在,每当我点击按钮时,它都不会删除该行,控制台也不会记录该语句。我只是想知道为什么成功和失败回调都不起作用。

非常感谢

1 个答案:

答案 0 :(得分:2)

由于您的服务器脚本未返回有效的JSON响应,因此它应调用失败回调(因为尝试在JSON失败时解析响应)。但该选项的正确名称为error:,而非failure:。所以改成它:

    error: function (data) {
        if (typeof (fail) === 'function') fail(data);
    }

如果服务器不应该发回JSON响应,请忽略dataType:选项,它不会尝试解析它。