假设我有一个订单和订单详细信息。
该视图将包含订单字段,以及用于显示详细信息的Telerik Grid
我总是在会话中维护订单的引用。
Session["Order"] = order;
当用户向网格添加订单详细信息时,我将其保存在订单引用中。
public ActionResult Grid_AddDetail(OrderDetail orderDetail) {
(Session["order"] as Order).Details.Add(orderDetail);
}
问题是,当我需要更新行时,我如何确定订单详细信息中的哪些详细信息已更新?
public ActionResult Grid_UpdateDetail(OrderDetail orderDetail) {
///how will i compare the element in the details, with the orderDetail?
(Session["order"] as Order).Details.IndexOf(orderDetail) = orderDetail;
}
这个问题可以通过添加一个序列号列来解决,并将传入的详细信息与我的引用中的现有值进行比较,方法是覆盖等于:
public overrid Equal(object obj){
return (obj as OrderDetail).Serial == this.Serial;
}
但是我希望序列号列是不可见的,但如果我这样做了,它将不会显示在传入的详细信息中。
发布于 2010-09-02 13:14:03
我所做的是:
添加了一个名为Serial的列
将列宽设置为0。
columns.Bound(m => m.Serial).Title("").Sortable(false).Width(0);
它将在(insert,update)中显示,但delete中的问题是使他(如Brett所说)成为Datakey。
public ActionResult Grid_AddDetail(OrderDetail orderDetail) {
if ((Session["order"] as Order).Details.Count != 0)
item.Serial= (Session["order"] as Order).Details.Max(d => d.Serial) + 1;
(Session["order"] as Order).Details.Add(orderDetail);
}
public ActionResult Grid_UpdateDetail(OrderDetail orderDetail) {
///order detail now contains the serial number.
(Session["order"] as Order).Details.IndexOf(orderDetail) = orderDetail;
}
发布于 2010-09-01 13:39:40
如果您只是想让该列不可见,我认为这会有所帮助:
AutoGenerateColumns="false"
这将迫使您生成显示信息的列,而不是自动为您创建它们的网格视图。因此,现在您需要执行以下操作才能显示订单
<asp:TemplateField>
<ItemTemplate>
<b><%# DataBinder.Eval(Container.DataItem, "Order") %>:</b>
</ItemTemplate>
</asp:TemplateField>
编辑:
要在序列号不可见时访问它,您需要使用DataKeys:
orderDetail.DataKeyNames = new string[] { "Serial" };
https://stackoverflow.com/questions/3618607
复制相似问题