【问题标题】:MVC Kendo Editable Grid not saving Enum valueMVC Kendo 可编辑网格不保存枚举值
【发布时间】:2020-03-03 20:29:00
【问题描述】:

我目前正在创建我的第一个剑道网格。几乎一切正常,除了我的 Status 枚举和 Code(基本上是一个 id)没有通过 Create 操作传递给我的控制器。

这是我的剑道网格(重要的部分)-

             @(Html.Kendo().Grid<MyViewModel>()
                .Name("grid")
                .AutoBind(false)
                .HtmlAttributes(new { @class = "grid-clickable-edit" })
                .Columns(columns =>
                {
                    columns.Command(command =>
                    {
                        command.Edit().IconClass("fas fa-pencil").UpdateIconClass("fas fa-check").CancelIconClass("fas fa-ban");
                        command.Destroy().IconClass("fas fa-trash");
                    })
                        .ClientHeaderTemplate(Html.GridAddButton())
                        .Width(180);
                    //some fields
                    columns.Bound(model => model.Code)
                        .EditorTemplateName("GridDropdownEditor")
                        .EditorViewData(new {data = ViewBag.CodeList})
                        .ClientTemplate("#:Code#");
                    //some other fields
                    columns.Bound(model => model.StatusId)
                        .EditorTemplateName("StatusEditor");
                        .ClientTemplate("#:StatusName#");
                    //more fields
                })
                .Pageable(pg => pg.Numeric(false).PreviousNext(false))
                .Sortable()
                .Scrollable(scroll => scroll.Virtual(true))
                .Filterable(x => x.Enabled(false))
                .Editable(editable => editable.Mode(GridEditMode.InLine))
                .DataSource(dataSource => dataSource
                    .Ajax()
                    .Batch(true)
                    .ServerOperation(true)
                    .Model(model => { model.Id(m => m.Id); })
                    .Read(...)
                    .Create(update => update.Action(...))
                    .Update(update => update.Action(...))
                    .Destroy(update => update.Action(...))
                ))


ViewBag.CodeList 是每个 Code 的 Id 的列表,以及描述。下拉菜单基本上显示了连接在一起的 id 和描述。

GridDropdownEditor -

@model object

@(Html.Kendo().DropDownListFor(m => m)
            .DataTextField("Text")
            .DataValueField("Value")
            .BindTo((IEnumerable<SelectListItem>)ViewData["data"])
)

状态编辑器 -

@using MyProject.Data.Models
@using MyProject.Helpers

@(Html.Kendo().DropDownListFor(m => m)
    .DataTextField("Text")
    .DataValueField("Value")
    .BindTo(EnumHelper<BidStatus>.ToSelectList())
    )
    )

EnumHelper.ToSelectList()方法基本上是从我的Status枚举中获取String和Id值,然后放到SelectList

状态枚举 -

public enum Status
{
    Status1 = 1,
    Status2 = 2,
    Status3 = 3
}


MyViewModel(同样,重要的部分)-

public int? Code { get; set; }

public Status? StatusId { get; set; }

public string StatusName
{
    get { return StatusId.ToString(); }
}



状态和代码的下拉列表填充得很好,但它们实际上从未被网格拾取并传递给控制器​​。仅供参考 - 代码和状态字段必须可以为空。如果需要更多信息,请告诉我,我很乐意提供。

我的尝试
我尝试使用此处的解决方案 - Kendo MVC grid with editable enum column,但这对我不起作用。

【问题讨论】:

    标签: c# kendo-ui kendo-grid kendo-asp.net-mvc


    【解决方案1】:

    我相信问题的发生是因为下拉列表绑定到对象集合,因此,在服务器上,绑定器无法将提交的对象映射到枚举值。

    您可以尝试将下拉菜单的ValuePrimitive设置为true,这样只会将值字段(Value)提交给服务器,而不是整个对象。

    例如

    @using MyProject.Data.Models
    @using MyProject.Helpers
    
    @(Html.Kendo().DropDownListFor(m => m)
        .DataTextField("Text")
        .DataValueField("Value")
        .ValuePrimitive(true)
        .BindTo(EnumHelper<BidStatus>.ToSelectList())
        )
        )
    

    对两个下拉菜单执行相同操作。

    【讨论】:

    • 解决了!非常感谢!
    猜你喜欢
    • 2015-09-26
    • 2016-03-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-04-03
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多