t. tivorc
t. tivorc

Reputation: 3

delete table row using jQuery within ajax statement

I want to delete a row from the table, but the success part of ajax does not execute.

function fn_delete() {
    $("a.delete").click(function () {
        idProduct = $(this).parents("tr").find("td").eq(1).html();
        $.ajax({
            type: "POST",
            url: "DeleteProduct",
            data: { idProduct },
            success: function () {
                $(this).parents("tr").fadeOut("normal", function () {
                $(this).remove();
            }
        });
    });
};

Upvotes: 0

Views: 25

Answers (2)

Grizzly
Grizzly

Reputation: 5953

I don't think this is giving the value that you're expecting.

Try this:

function fn_delete() {
$("a.delete").click(function () {
    idProduct = $(this).parents("tr").find("td").eq(1).html();
    var myRow = $(this).parents("tr");
    $.ajax({
        type: "POST",
        url: "DeleteProduct",
        data: { idProduct },
        success: function () {
                $(this).parents("tr").fadeOut("normal", function () {
                myRow.remove();
            });
        }
    });
});

Upvotes: 0

David Hedlund
David Hedlund

Reputation: 129832

this inside your success callback will not be the same as this in the code that makes the ajax call, unless you explicitly set the context:

$.ajax({
  context: this,
  data: ...
});

Upvotes: 1

Related Questions