Kendo Grid:外键下拉列表在更新后不更新网格单元格

时间:2013-11-01 15:27:39

标签: asp.net-mvc grid telerik kendo-ui

我有一个Kendo MVC网格,其中包含一个绑定为外键的可空属性(short),并使用下拉列表作为编辑器模板。我也在使用内联编辑。

当属性值为null时,单击更新按钮后,下拉列表选定值不会设置到网格单元格中。如果使用单元格编辑,这可以正常工作。我正在寻找一种可以解决我的问题的解决方法。我在下面包含了我的代码的精简版

如果可以为null的值设置为非空值,则一切正常。

GRID

@(Html.Kendo().Grid<AssetViewModel>()
   .Name("DealAssets")
   .Columns(c =>
   {
      c.Bound(x => x.Name);
      c.ForeignKey(x => x.AssetTypeID, (IEnumerable<SelectListItem>)ViewBag.AssetTypeList, "Value", "Text");
      c.ForeignKey(x => x.SeniorityTypeID, seniorityTypeList, "Value", "Text").EditorTemplateName("GridNullableForeignKey");
      c.ForeignKey(x => x.RateBaseID, rateBaseList, "Value", "Text").EditorTemplateName("GridNullableForeignKey"); ;
      c.Command(m => { m.Edit(); m.Destroy(); });
   })
   .ToolBar(toolbar => toolbar.Create().Text("Add New Asset"))
   .Editable(x => x.Mode(GridEditMode.InLine))
   .DataSource(ds => ds
      .Ajax()
      .Model(model => model.Id(request => request.ID))
      .Read(read => read.Action("ReadAssets", "Deal", new { id = Model.ID }))
      .Create(create => create.Action("CreateAsset", "Deal", new { currentDealID = Model.ID }))
      .Update(update => update.Action("UpdateAsset", "Deal"))
      .Destroy(destroy => destroy.Action("DeleteAsset", "Deal"))
   )
)

编辑模板

@model short?
@{
   var controlName = ViewData.TemplateInfo.GetFullHtmlFieldName("");
}
@(
   Html.Kendo().DropDownListFor(m => m)
      .Name(controlName)
      .OptionLabel("- Please select -")
      .BindTo((SelectList)ViewData[ViewData.TemplateInfo.GetFullHtmlFieldName("") + "_Data"])
)

更新行动

public ActionResult UpdateAsset([DataSourceRequest] DataSourceRequest request, int ID)
{
   var dealAsset = DataContext.DealAssets.SingleOrDefault(o => o.ID == ID);
   if (dealAsset != null)
   {
      if (TryUpdateModel(dealAsset.Asset, new[] {"Name","AssetTypeID","SeniorityTypeID","RateBaseID" }))
      {
         DataContext.SaveChanges();
      }
   }
   return Json(new[] { new AssetViewModel(dealAsset) }.ToDataSourceResult(request, ModelState), JsonRequestBehavior.AllowGet);
}

1 个答案:

答案 0 :(得分:12)

Telerik刚刚在他们的选择列表中添加了一个新的HTML属性data_value_primitive,以解决上述问题。新属性应添加到外键编辑器模板中并设置为true。

 Html.Kendo().DropDownListFor(m => m)
        .Name(controlName)
        .OptionLabel("- Please select -")
        .BindTo((SelectList)ViewData[ViewData.TemplateInfo.GetFullHtmlFieldName("") + "_Data"])
        **.HtmlAttributes(new { data_value_primitive = true})**

最后一节是对update方法的修改,用于说明在执行ajax调用时网格没有传回null属性。我认为这更多地与TryUpdateModel方法的工作方式有关

...
if (TryUpdateModel(dealAsset.Asset, new[] {"Name","AssetTypeID","SeniorityTypeID","RateBaseID" }))
{
   // If no property passed back then set it to null
   var senorityTypeID = ValueProvider.GetValue("SeniorityTypeID");
   if (senorityTypeID == null)
   {
      dealAsset.Asset.SeniorityTypeID = null;
   } else {
      dealAsset.Asset.SeniorityTypeID = (short)senorityTypeID.ConvertTo(typeof(short));
   }
   var rateBaseID = ValueProvider.GetValue("RateBaseID");
   if (rateBaseID == null)
   {
      dealAsset.Asset.RateBaseID = null;
   } else {
      dealAsset.Asset.RateBaseID = (byte)rateBaseID.ConvertTo(typeof(byte));
   }
   DataContext.SaveChanges();
}
'''