我有一个带有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并在其中使用复选框外,还有其他解决方案吗?我认为必须有一个更简单的方法,但谷歌没有给我答案。
任何帮助都将不胜感激。
答案 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));
}