如何检查Gridview中的CheckBoxField是否已被选中?

时间:2011-02-22 13:56:26

标签: c# asp.net gridview

我有一个带有GridView的webform。在这个GridView中,我有一个数据绑定CheckBoxField。我还有一个可编辑的数据绑定字段,带有状态码(订单状态代码)。

我想要实现的目标如下:

如果用户编辑了一行,并选中了复选框,则状态代码需要分配一个新值,以防用户忘记更新状态代码。

ASP.Net:

<asp:GridView ID="gvRestordrer" runat="server" DataSourceID="basketConn2" AutoGenerateColumns="False" DataKeyNames="k_ordre_id" CssClass="gvBasket" GridLines="None" Width="706px" AllowPaging="true" PageSize="10" OnRowEditing="getOrderDetails" OnRowCancelingEdit="clearOrderDetails" OnRowUpdating="clearOrderDetails">
    <RowStyle CssClass="gvRow" />
    <Columns>
    ...
    // BoundField with statuscode. This value need to be updated on rowupdating, if Checkboxfield has been checked by the user
    <asp:BoundField DataField="k_order_statuscode" HeaderText="Statuscode" SortExpression="k_order_statuscode" >
        <HeaderStyle CssClass="gvHeader" />
    </asp:BoundField>
    // Checkboxfield bound to a database bool "k_order_completed"
    <asp:CheckBoxField DataField="k_order_completed" HeaderText="Completed?" SortExpression="k_order_completed" >
        <HeaderStyle CssClass="gvHeader" />
    </asp:CheckBoxField>
    // Commandfield
    <asp:CommandField DeleteText="" EditText="Handle Order" ShowDeleteButton="True" ShowEditButton="True" UpdateText="Update Order" >
        <HeaderStyle CssClass="gvHeader" />
    </asp:CommandField>
...
</asp:GridView>

C#stuff:

protected void clearOrderDetails(object sender, GridViewUpdateEventArgs e)
    {
        lblOrdreDetaljer.Text = "";
        int index = Convert.ToInt32(e.RowIndex);

        // Not working
        if (gvRestordrer.Rows[index].Cells[4].Value == true)
        {
            basketConn2.UpdateParameters["k_order_statuscode"].DefaultValue = "4";
        }
    }

除了制作TemplateField并在其中使用复选框外,还有其他解决方案吗?我认为必须有一个更简单的方法,但谷歌没有给我答案。

任何帮助都将不胜感激。

1 个答案:

答案 0 :(得分:1)

这对于数据绑定复选框可能不起作用,但这是我为gridview中的复选框执行的操作。

到目前为止,我已经能够通过以下方式获得检查项目:

复选框被添加到gridview:

 internal static void AddCheckboxes(System.Web.UI.WebControls.GridView gv,IEnumerable<int> checkedRows)
    {
        foreach (var item in gv.Rows.Cast<System.Web.UI.WebControls.GridViewRow>().Select(c => c.Cells[0]).Where(cell => cell.Controls.Count == 0).WithIndex())
            item.Item1.Controls.Add(new System.Web.UI.WebControls.CheckBox() { ClientIDMode = System.Web.UI.ClientIDMode.Static, ID = "ckUpdate" + item.Item2, Checked = checkedRows != null && checkedRows.Contains(item.Item2) });
    }

然后在回发中使用

 internal static IEnumerable<int> GetCheckedRows(IEnumerable<string> paramKeys)
    {
        return paramKeys
            .Where(f => f.Contains("$"))
            .Where(f => System.Text.RegularExpressions.Regex.IsMatch(f, "ckUpdate[0-9]+$"))
            .Select(p => int.Parse(System.Text.RegularExpressions.Regex.Match(p, "[0-9]+$").Value));

    }

然后调用

 GetCheckedRows(Request.Params.AllKeys).ToList();

助手:

public static IEnumerable<Tuple<T, int>> WithIndex<T>(this IEnumerable<T> enumerable)
    {
        return enumerable.Select((item, index) => Tuple.Create(item, index));
    }