Jquery 数据表从按钮单击获取行 ID

新手上路,请多包涵

我的数据表中的每一行都有两个按钮,编辑和删除。是否可以在单击“删除”或“编辑”按钮时获取员工的 ID 或行的 ID,并将该 ID 值传递到我拥有的 Web 方法中,该方法采用 ID 参数以从数据库中删除记录?

到目前为止我的 jquery 代码:

  $(document).ready(function () {
        $.support.cors = true;
        $.ajax({
            url: '<%=ResolveUrl("GetEmployee.aspx") %>',
            type: 'POST',
            contentType: 'application/json; charset=utf-8',
            dataType: 'json',
            success: function (data) {
              var table = $('#datatable').dataTable({
                    data: data,
                    columns: [
                        { 'data': 'Id' },
                        { 'data': 'image' },
                        { 'data': 'lastName' },
                        { 'data': 'firstName' },
                        { 'data': 'jobTitle' },
                        {
                            'data': 'StartDate',
                            'render': function (jsonDate) {
                                var date = new Date(parseInt(jsonDate.substr(6)));
                                var month = date.getMonth() + 1;
                                return date.getDate() + "/" + month + "/" + date.getFullYear();
                            }
                        },
                        {
                            'data': 'EndDate',
                            'render': function (jsonDate) {
                                var date = new Date(parseInt(jsonDate.substr(6)));
                                var month = date.getMonth() + 1;
                                return date.getDate() + "/" + month + "/" + date.getFullYear();
                            }
                        },
                        {
                            'data': null,
                            'render': function (data, type, row) {
                                return '<button id="' + row.id +'" onclick="editClick()">Edit</button>'
                            }
                        },
                        {
                            'data': null,
                            'render': function (data, type, row) {
                                return '<button id="' + row.id + '" class="dodo" onclick="deleteClick()">Delete</button>'
                            }
                        }
                    ]
                });
            }
        });

        $('#datatable').on('click', 'button', function () {
            var id = $(this).data();
            //var id = table.row($(this)).data();
            alert(JSON.stringify(id));
        });
    });

现在,当我尝试获取 id 时,它会返回一个未定义的值。

我的网络方法:

   [WebMethod]
    public static void DeleteRecord(string id)
    {
        var query = "DELETE FROM employee WHERE ID=?";
        OdbcConnection myConn = new OdbcConnection(myConnection);
        OdbcTransaction transaction = null;
        myConn.Open();

        transaction = myConn.BeginTransaction();
        OdbcCommand command = new OdbcCommand(query, myConn, transaction);
        command.Parameters.Add("ID", OdbcType.Int).Value = id;
        command.ExecuteNonQuery();

        transaction.Commit();

        myConn.Close();
    }

谢谢!

原文由 SC.Cee 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 476
2 个回答

是的,您可以在单击按钮时同时获得员工 ID 或行 ID。为此,您需要在定义编辑和删除按钮时执行一些小的更改。

 {
     'data': null,
     'render': function (data, type, row) {
                   return '<button id="' + row.id +'" onclick="editClick(this)">Edit</button>'
               }
},
{
     'data': null,
     'render': function (data, type, row) {
                       return '<button id="' + row.id + '" class="dodo" onclick="deleteClick(this)">Delete</button>'
               }
}

Javascript/jQuery

 function editClick (obj) {
      var rowID = $(obj).attr('id');
      var employeeID = $(obj).closest('tr').find('td:first').html());
}

function deleteClick (obj) {
      var rowID = $(obj).attr('id');
      var employeeID = $(obj).closest('tr').find('td:first').html());
}

原文由 Suprabhat Biswal 发布,翻译遵循 CC BY-SA 3.0 许可协议

我可能知道三种方法。

1 种坏方法:例如,为后端获取数据 缺点 短路和搜索…功能已禁用。额外的回应。

 <a data-id="<?=yourQueryResult["id"]?>" onclick="javascript:foo()"></a>
function foo (){ var id = $(this)attr("data-id")}

或者

<a onclick="javascript:foo(<?=yourQueryResult["id"]?>)"></a>
function foo(id){ /*deleting*/}

2 on render function go javascript方法参数row id 例子

render': function (data, type, row) {
                   return '<a onclick="javascript:foo('+ row.id +')"></a>'
               }

3 我最喜欢的 direck jquery 事件侦听器获取行数据优点:干净的 html,没有内联函数调用和所有函数相同的文件调用。

 var table = $('#datatable').dataTable({...})

$('#datatable tbody').on('click', 'a.delete', function () {
            var tr = $(this).closest('tr');
            var row = table.row(tr);
            var id = row.data().yourColumnName;
        });
$('#datatable tbody').on('click', 'a.edit', function () {
                var tr = $(this).closest('tr');
                var row = table.row(tr);
                var rowData = row.data();
            });

原文由 Qh0stM4N 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题