コメントを削除すると、実際のコメント数が含まれないように rowCount が更新されません。ビューからフェードアウトさせたいので、 remove() 関数ではなく、フェードアウト関数を使用するためです。
最初にフェードアウトしてから削除するにはどうすればよいですか?
これを試してみましたが、それは役に立ちませんでした:
$('#item_'+DbNumberID).fadeOut("slow", function() {
$(this).remove();
});
コード:
jQuery.ajax({
type: "POST",
url: "delete-comment.php",
dataType:"text",
data:myData,
success: function(response){
$('#item_'+DbNumberID).fadeOut("slow");
var rowCount = $('#comment li').length;
alert(rowCount);
return false;
},
error: function (xhr, ajaxOptions, thrownError){
alert(thrownError);
}
});
編集:
これが私の完全なコードです。モードシンプルにできますか?
//##### Send delete Ajax request to response.php #########
$("body").on("click", "#comment .del_button", function(e) {
e.preventDefault();
//e.returnValue = false;
var clickedID = this.id.split('-'); //Split string (Split works as PHP explode)
var DbNumberID = clickedID[1]; //and get number from array
var myData = 'action=delete&id='+ DbNumberID; //build a post data structure
jQuery.ajax({
type: "POST", // HTTP method POST or GET
url: "add-comment.php", //Where to make Ajax calls
dataType: "text", // Data type, HTML, json etc.
data: myData, //Form variables
success: function(response){
//on success, hide element user wants to delete.
$('#item_'+DbNumberID).fadeOut(500, function() {
setTimeout(function() {
$('#item_'+DbNumberID).remove();
}, 500);
});
var rowCount = $('#comment li').length;
rowCount--;
alert(rowCount);
if (rowCount == 0) {
$("#comment").html('<div class="PageWarning">No comments.</div></div>');
}
return false;
},
error:function (xhr, ajaxOptions, thrownError){
//On error, we alert user
alert(thrownError);
}
});
});