3

我无法从 datagrid 检索不可见列的值。如果列不可见,如何获取值?

这是我的代码:

数据网格:

<asp:BoundField DataField="id" HeaderText="ID" ReadOnly="True" 
            Visible="False" />
        <asp:BoundField DataField="category" HeaderText="Category" />
        <asp:CommandField ShowDeleteButton="True" ShowEditButton="True" 
            ShowHeader="True" />

行删除事件

 protected void dgvCategory_RowDeleting(object sender, GridViewDeleteEventArgs e)
    {
        string id = dgvCategory.Rows[e.RowIndex].Cells[0].Text;

        string name = dgvCategory.Rows[e.RowIndex].Cells[1].Text;

        runDelete(id, name);

        loadDataCategory();            

    }

我该如何解决我的问题?

4

1 回答 1

4

您可以将此 ID 列添加为 DataKey

在你的 aspx

<asp:GridView DataKeyNames="id" ....

在你的活动中

protected void dgvCategory_RowDeleting(object sender, GridViewDeleteEventArgs e)
{
    var key = this.GridView1.DataKeys[e.RowIndex].Value.ToString();
}

其他选项是使用 css 样式隐藏列

使用创建新的 css 类并将display: none;其应用于您的. 删除财产。ItemStyle-CssClassHeaderStyle-CssClassBoundFieldVisible="False"

现在您可以获取其他列的值,但它不会显示在客户端 UI 中。

于 2013-08-15T03:13:17.487 回答