无法使用dataTable jquery删除表上新添加的行

时间:2014-08-02 08:17:27

标签: javascript jquery html ajax datatable

我有一个html表,其中包含来自数据库的内容,使用ajax和php。

当我尝试通过填写所有输入手动添加新行并单击“保存”按钮时,它会将数据添加到表中。

我的问题是当我尝试删除新添加的行并单击该特定行上的删除按钮时,它不会删除。但是当我尝试删除来自数据库的行时,它将从html表中删除。

脚本:

$.ajax({
url: 'process.php',
type: 'post',
data: {tag: 'getData'},
dataType: 'json',
success: function(data){
        if(data.success){
            $("#myTable2 tbody").empty(); 
            $.each(data, function(index, record){
                if($.isNumeric(index)){
                    var row = $("<tr />");
                    $("<td />").text(record.name).appendTo(row);
                    $("<td />").text(record.age).appendTo(row);
                    $("<td />").text(record.gender).appendTo(row);
                    $("<td />").html(record.action).appendTo(row);
                    row.appendTo("#myTable2 tbody");
                }
            })
            }   

            var oTable = $('#myTable2').DataTable();

            $("#myTable2 tbody .dltRow").bind( 'click', function(event) {
                var row = $(this).closest('tr').get(0);
                oTable.row(row).remove().draw();

                oTable.row($(this).closest('tr')).remove().draw();
                $(this).parent().parent().closest('tr').remove();
                oTable.fnDeleteRow(oTable.fnGetPosition(row));

            });                 

            $('#Save2').on( 'click', function () {
                var data = [
                    $('#name').val(),
                    $('#age').val(),
                    $("[name='gender']:checked").val(),
                    "<center><button type='button' class='btn btn-default dltRow'><i class='glyphicon glyphicon-trash'></i></button></center>"
                    ];

                oTable.row.add(data).draw();
            });

        }

});

1 个答案:

答案 0 :(得分:2)

使用事件委派将事件附加到动态添加的删除按钮。

 $("#myTable2 tbody").on( 'click','.dltRow', function(event) {
            var row = $(this).closest('tr').get(0);
            oTable.row(row).remove().draw();

            oTable.row($(this).closest('tr')).remove().draw();
            $(this).parent().parent().closest('tr').remove();
            oTable.fnDeleteRow(oTable.fnGetPosition(row));

        });