Telerik Grid для ASP.NET MVC2 AJAX Привязка не работает / маршруты для неправильных действий
-
10-10-2019 - |
Вопрос
Gird загружает B/C привязки сервера. Все остальные действия либо публикуются по неправильному маршруту, либо в действие по умолчанию: вставьте сообщения в /editorder Действие Редактировать сообщения на этот адрес:http: // localhost: 20588/orders/editorder/sdsddd? orderid = 2 & customerid = 1 & itemsinordergrid-mode = editчто является бессмысленным (SDSDD - это элемент), не связанный с точками останова внутри секций AJAX в контроллере. Есть идеи, что я делаю не так?
Спасибо, Дани
Вот код просмотра:
<%=
Html.Telerik().Grid(Model.ItemsInOrderList)
.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("ItemsGridAjax", "Orders", new {OrderID = Model.order.OrderID})
.Insert("InsertItemsGridAjax", "Orders", new {OrderID = Model.order.OrderID})
.Update("UpdateItemsGridAjax", "Orders")
.Delete("DeleteItemsGridAjax", "Orders"))
//.BindTo(Model.ItemsInOrderList)
.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(200);
})
%>
Вот код в контроллере:
[GridAction]
public ActionResult ItemsGridAjax(int OrderID)
{
return View(ordersRepository.GetOrderItemsTK(OrderID));
}
[HttpPost]
[GridAction]
public ActionResult InsertItemdGridAjax(int OrderID)
{
//Create a new instance of the EditableCustomer class.
ItemsInOrder newItem = ItemsInOrder.CreateItemsInOrder(OrderID, "");
newItem.OrderID = OrderID;
//Perform model binding (fill the customer properties and validate it).
if (TryUpdateModel(newItem))
{
//The model is valid - insert the customer.
bool res = ordersRepository.InsertItemToOrder(OrderID, newItem);
}
//Rebind the grid
return View(ordersRepository.GetOrderItemsTK(OrderID));
}
[HttpPost]
[GridAction]
public ActionResult UpdateItemsGridAjax(int OrderID, string ItemID)
{
//Find a customer whose CustomerID is equal to the id action parameter
ItemsInOrder item = ordersRepository.FindItemByID(OrderID,ItemID);
if (item != null)
{
//Perform model binding (fill the customer properties and validate it).
if (TryUpdateModel(item))
{
//The model is valid - update the customer and redisplay the grid.
ordersRepository.UpdateItem(item);
}
}
// TODO: Add try-catch with error reporting.
//Rebind the grid
return View(ordersRepository.GetOrderItemsTK(OrderID));
}
[HttpPost]
[GridAction]
public ActionResult DeleteItemsGridAjax(int OrderID, string ItemID)
{
//Find the customer with the specified id
ItemsInOrder item = ordersRepository.FindItemByID(OrderID, ItemID);
if (item != null)
{
//Delete the customer
ordersRepository.DeleteItem(item);
}
//Rebind the grid
return View(ordersRepository.GetOrderItemsTK(OrderID));
}
Решение
Я не уверен, что вам нужно [HttpPost]
атрибут (я думаю просто [GridAction]
будет достаточно) для этих действий AJAX, возможно, попробуйте их удалить и посмотреть, решает ли это проблему.
Если это не сработало, попробуйте вернуть GridModel
в ваших действиях, как это:
[GridAction]
public ActionResult InsertItemdGridAjax(int OrderID)
{
//Omitted Code
return View(new GridModel(ordersRepository.GetOrderItemsTK(OrderID)));
}
Вы также можете использовать синтаксис, похожий на следующее (как я думаю GridModel
любит иметь total
):
[GridAction]
public ActionResult InsertItemdGridAjax(int OrderID)
{
//Omitted Code
//Get List of Order Items
List<OrderItem> list = ordersRepository.GetOrderItemsTK(OrderID));
return View(new GridModel
{
Data = list,
Total = list.Count
});
}
Другие советы
У A была такая же проблема, но в MVC 3
Решение было просто добавить соответствующие сценарии *.js в проект, см. этои добавить @(Html.Telerik().ScriptRegistrar().jQuery(false))
в конце файла _layout.cshtml
Тогда маршрутизация идет нормально!