我想要做的是在下拉列表中显示公司名称的文本和单元格(当它没有被编辑时),但公司的ID是在“保存时”传递回服务器的数据“点击了。
一切都很完美,除了当我点击下一个单元格以继续我的编辑(导致DDL的单元格退出编辑模式)时,其所在位置的只读单元格显示ID而不是公司名称。
这张照片说明了我的意思:
有没有人知道解决这个问题的方法,或者采用不同的方法来实现我需要的功能?
编辑模板
@(Html.Kendo().DropDownList()
.Name("Company")
.DataTextField("Name")
.DataValueField("EnterpriseID")
.BindTo((IEnumerable<BlueGrace.BlueShip.Business.Enterprise.EnterpriseChildListingItem>)ViewBag.RefCarrierLiabilityEnterpriseListing))
控制器(ViewBag人口)
var enterpriseListing = Business.Enterprise.EnterpriseChildListing.Get(false, customIdentity.EnterpriseID, false).ToList();
ViewBag.RefCarrierLiabilityEnterpriseListing = enterpriseListing;
查看
@(Html.Kendo().Grid(Model.GlobalDictionary.RefCarrierLiabilityModels)
.Name("CarrierLiabilityDictionaryGrid")
.Columns(columns =>
{
columns.Bound(item => item.CarrierName)
.EditorTemplateName("RefCarrierListing").Width(250);
columns.Bound(item => item.Company)
.EditorTemplateName("RefCarrierLiabilityEnterpriseListing");
columns.Bound(item => item.MaxLiability)
.EditorTemplateName("RefCarrierLiabilityMaxLiability");
columns.Bound(item => item.IsValueOfGoodsMaxLiability);
columns.Command(command =>
{
command.Destroy();
}).Width(100);
})
.ToolBar(toolbar =>
{
toolbar.Create();
toolbar.Save();
})
.Editable(editable => editable.Mode(GridEditMode.InCell).CreateAt(GridInsertRowPosition.Top))
.Pageable()
.Sortable()
.Scrollable()
.Filterable()
.Resizable(resize => resize.Columns(true))
.Reorderable(reorder => reorder.Columns(true))
.DataSource(dataSource => dataSource
.Ajax()
.Batch(true)
.ServerOperation(false)
.Model(model =>
{
model.Id(i => i.RefCarrierLiabilityID);
model.Id(i => i.RefCarrierID);
})
.Read(read => read.Action("GetCarrierLiabilities", "Dictionary"))
.Create(create => create.Action("CreateCarrierLiabilities", "Dictionary"))
.Update(update => update.Action("UpdateCarrierLiabilities", "Dictionary"))
.Destroy(delete => delete.Action("DeleteCarrierLiabilities", "Dictionary"))
)
)
答案 0 :(得分:1)
Grid提供了一个名为 ForeignKey 列的功能,我猜你需要它。查看此演示(将源更改为.cshtml以查看您需要执行的所有操作)。
columns.ForeignKey(p => p.EmployeeID, (System.Collections.IEnumerable)ViewData["employees"], "EmployeeID", "EmployeeName");