1

OrderId、ItemID という複合キーを持つグリッドがあります。グリッドを更新すると、グリッド public ActionResult UpdateItemGridAjax(int OrderID, string ItemID)から両方の値を取得します。

行を削除すると、最初の行のみが取得されます。

public ActionResult DeleteItemGridAjax(int OrderID, string ItemID)

なぜそれが起こるのですか?削除された行の ItemId 値を取得するにはどうすればよいですか?

グリッド定義:

<%= 
                Html.Telerik().Grid<ItemsInOrderPOCO>()

                    .Name("ItemsInOrderGrid")
                                    .DataKeys(dataKeys =>
                                    {
                                        dataKeys.Add(e => e.OrderID);
                                        dataKeys.Add(e => e.ItemID);
                                    })

                    .ToolBar(commands => commands.Insert())
                   .DataBinding(dataBinding => 
                        {
                        dataBinding.Ajax()    //Ajax binding

                .Select("SelectItemGridAjax", "Orders", new { OrderID = Model.myOrder.OrderID })
                .Insert("InsertItemGridAjax", "Orders", new { OrderID = Model.myOrder.OrderID })

                .Update("UpdateItemGridAjax", "Orders")

                .Delete("DeleteItemGridAjax", "Orders");
                        })
                    .Columns(c =>
                        {
                            c.Bound(o => o.ItemID);
                            c.Bound(o => o.OrderID).Column.Visible = false; 
                            c.Bound(o => o.ItemDescription);
                            c.Bound(o => o.NumOfItems);
                            c.Bound(o => o.CostOfItem);
                            c.Bound(o => o.TotalCost);
                            c.Bound(o => o.SupplyDate);
                            c.Command(commands =>
                                {
                                    commands.Edit();
                                    commands.Delete();
                                }).Width(180).Title("Upadte");
                        })
4

1 に答える 1

3

2 番目のキーは、ItemID ではなく Id として返されます。コードでそれを定義する方法があります:

       .DataKeys(dataKeys =>
            {
              dataKeys.Add(e => e.OrderID).RouteKey("OrderID");
              dataKeys.Add(e => e.ActivityID).RouteKey("ActivityID");
            })

これにより、期待するものを手に入れるチャンスが増えます。

于 2011-01-16T13:46:56.703 に答える