Kendo UI外键列的自定义编辑器模板

时间:2013-03-25 08:17:19

标签: asp.net-mvc entity-framework razor kendo-ui kendo-grid

我正在使用KendoUI ASP Wrapper,我需要帮助将“ActivityCodeID”的默认ForeignKey编辑器更改为AutoComplete。我该如何改变呢?

@(Html.Kendo().Grid<TimeEntry>()
    .Name("grid-timeentry-project")
    .DataSource(datasource => datasource.Ajax()
        .Model(model =>
                    {
                        model.Id(record => record.TimeEntryID);
                        model.Field(f => f.TimeSheetID).DefaultValue(0);
                        model.Field(f => f.TimeEntryTypeID).DefaultValue(ViewBag.ProjectTimeEntryTypeId);
                        model.Field(f => f.ActivityCodeID);
                        model.Field(f => f.Description);
                        model.Field(f => f.Duration);
                        model.Field(f => f.DateAdded);                     
                    })
        .Read(read => read.Action("GetProjectTimeEntries", "TimeEntry"))
    )
    .Columns(columns =>
                 {
                     columns.Bound(r => r.TimeEntryID).Hidden(true);
                     columns.Bound(r => r.TimeSheetID).Hidden(true);
                     columns.Bound(r => r.TimeEntryTypeID).Hidden(true);
                     columns.ForeignKey(r => r.ActivityCodeID, (System.Collections.IEnumerable)ViewData["AllActivityCodes"], "ActivityCodeID", "ActivityCode1").Title("ActivityCode");                                         
                     columns.Bound(r => r.Description);
                     columns.Bound(r => r.Duration).Title("Duration (s)");
                     columns.Command(command => { command.Edit(); command.Destroy(); }).Width(170);
                 })
      )

我尝试修改我的EF模型的DataAnnotation并声明了EditorTemplate但它仍然使用默认的“GridForeignKey”editortemplate。

这是我的EF。

[MetadataType(typeof(TimeEntryMetaData))]
public partial class TimeEntry
{
}

public class TimeEntryMetaData
{
    [UIHint("ActivityCodeIDEditor")]
    public int ActivityCodeID { get; set; }
}

这是我的“ActivityCodeIDEditor”编辑器模板。我无法获得“asdf”,因此假设不考虑编辑器模板。

    @model object
<span>asdf</span>
@*@(
 Html.Kendo().DropDownListFor(m => m)        
        .BindTo((SelectList)ViewData[ViewData.TemplateInfo.GetFullHtmlFieldName("") + "_Data"])

请帮忙。谢谢!       )* @

1 个答案:

答案 0 :(得分:4)

有一种特殊的列方法,可让您指定编辑器模板的名称。试试

columns.bound(x=>x.some).EditorTemplateName("foo");