使用 GridTemplateColumn 中的 DataKeyNames 和 CheckBox 查看选中了哪些行?

Use DataKeyNames and CheckBox in GridTemplateColumn to see what rows have been selected?

我们有一个带有 radgrid 和按钮的网络表单。 radgrid 有两列和一个复选框列。

在 Page_load 上,将显示数据,用户将能够 select(通过复选框)随着 EmpId 的更新将经过哪些行;如果该行是 selected,则 NewEmpId 将替换 OldEmpId。单击“更新”按钮并进行更改。

我遇到的问题是我更喜欢使用数据键名从每一行中检索数据。但是我在不使用 GridCheckBoxColumn 的情况下实现它时遇到了麻烦,我不想使用它,因为 radgrid 需要处于编辑模式才能 selected 复选框,这会带来其他问题。

<telerik:RadGrid ID="RadGridEmp" runat="server" AutoGenerateColumns="False" Width="100%" AllowPaging="True" PageSize="22">
    <ClientSettings>
      <Selecting AllowRowSelect="True" />
    </ClientSettings>
    <mastertableview commanditemdisplay="TopAndBottom" datakeynames="OldEmpId, NewEmpId, EmpName">
        <commanditemsettings showaddnewrecordbutton="false" />
            <Columns>
                <telerik:GridBoundColumn DataField="OldEmpId" HeaderText="OldEmpId">
                    <HeaderStyle Width="110px"></HeaderStyle>
                </telerik:GridBoundColumn>
                <telerik:GridBoundColumn DataField="NewEmpId" HeaderText="NewEmpId">
                    <HeaderStyle Width="110px"></HeaderStyle>
                </telerik:GridBoundColumn>
                <ItemTemplate>
                    <asp:CheckBox ID="ChkChange" runat="server" />
                </ItemTemplate>
                </telerik:GridTemplateColumn>
            </Columns>
    </mastertableview>
</telerik:RadGrid>

下面的代码只是我更喜欢用在这个问题上的代码。它使用数据键名。但它没有建立:

protected void RadButtonUpdateSectors_Click(object sender, EventArgs e)
{
    foreach (GridItem item in RadGridEmp.MasterTableView.Items)
    {
        GridDataItem dataitem = (GridDataItem)item;
        TableCell cell = dataitem["GridCheckBoxColumn"];
        CheckBox checkBox = (CheckBox)cell.Controls[0];
        if (checkBox.Checked)
        {
            oldEmpId = dataitem.GetDataKeyValue("OldEmpId").ToString();
            newEmpId = dataitem.GetDataKeyValue("NewEmpId").ToString();
            UpdateEmpId(oldEmpId, newEmpId, connString);
        }
    }
}

请尝试使用以下代码片段。

datakeynames="OldEmpId,NewEmpId,EmpName"
...............
...............
protected void RadButtonUpdateSectors_Click(object sender, EventArgs e)
{
    foreach (GridDataItem item in RadGridEmp.MasterTableView.Items)
    {
        CheckBox ChkChange = item.FindControl("ChkChange") as CheckBox;
        if (ChkChange.Checked)
        {
            string oldEmpId = item.GetDataKeyValue("OldEmpId").ToString();
            string newEmpId = item.GetDataKeyValue("NewEmpId").ToString();
            UpdateEmpId(oldEmpId, newEmpId, connString);
        }
    }
}

如有任何疑问,请告诉我。

注意:- 从数据键名中删除多余的 space。