私はテーブルを持っており、削除ボタンがあります。基本的に私がやりたいことは、削除ボタンをクリックすると、私たちのサーバーにDELETE要求を送信し、dbを更新することです。成功すると、テーブルからその行が削除されます。AJAX成功失敗コールバックが機能しない
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");
}
);
}
});
今、私はボタンをクリックするたびに、その行を削除しないであろうと、コンソールはそのログません。ステートメント。成功と失敗のコールバックがうまくいかない理由は不思議です。サーバースクリプトが有効なJSONレスポンスを返していない
どうもありがとう
コンソールログにエラーがありますか?ブラウザの[ネットワーク]タブを確認すると、AJAXリクエストを送信していますか? – Barmar
@Barmarコンソールログにエラーはありません。実際にajaxリクエストが送信され、その行がdb内で削除されたことがわかります – singard
[ネットワーク]タブでJSONレスポンスが表示されますか? – Barmar