asp.net-mvc - 使用 AJAX 绑定(bind)时创建/更新后具有 IEnumerable 属性的 Kendo Grid 模型未正确更新

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

我遇到了一个问题,即在将模型的属性发送到我的 Controller 以从 Kendo Grid 进行 Update 或 Create 调用时未正确更新它。该模型如下所示:

public class ReleaseNotesModel
{
    public int NoteID { get; set; }
    public int ReleaseID { get; set; }
    public List<TranslationModel> ReleaseNoteTranslations { get; set; }
    public ReleaseNoteType ItemType { get; set; }
}
public class TranslationModel
{
    public int TranslationID { get; set; }
    public string Translation { get; set; }
    public int LanguageID { get; set; }
    public int ItemID { get; set; }
}

这是我认为的网格:
@(Html.Kendo().Grid<ReleaseNotesModel>()
    .Name("Grid")
    .Columns(columns =>
    {
        columns.Bound(m => m.ItemType).Width(140);
        columns.Bound(m => m.Description);
        columns.Command(command =>
            {
                command.Edit();
                command.Destroy();
            }).Width(170);
    })
    .ToolBar(toolbar => toolbar.Create())
    .Editable(editable => editable
        .Mode(GridEditMode.PopUp)
        .TemplateName("ReleaseNoteTemplate")
        .Window(w => w.Width(620))
        .DisplayDeleteConfirmation(true)
    )
    .Pageable()
    .Sortable()
    .Scrollable()
    .Filterable()
    .DataSource(dataSource => dataSource
        .Ajax()
        .ServerOperation(false)
        //.Server()
        .Events(e => e.Error("grid_error"))
        .Model(model =>
        {
            model.Id(m => m.NoteID);
            model.Field(m => m.ReleaseID).DefaultValue(Model.ReleaseID);
            model.Field(m => m.ItemType).DefaultValue(ReleaseNoteType.NewFeature);
            //defaultTranslationsList is a List<TranslationModel> with two empty objects in it
            model.Field(m => m.ReleaseNoteTranslations).DefaultValue(defaultTranslationsList);
        })
        .PageSize(5)
        .Read(read => read.Action("GetNotes", "ReleaseNotes", new { releaseID = Model.ReleaseID }))
        .Create(create => create.Action("AddNote", "ReleaseNotes"))
        .Update(update => update.Action("EditNote", "ReleaseNotes"))
        .Destroy(destroy => destroy.Action("DeleteNote", "ReleaseNotes"))
    )
)

更具体地说,我遇到的问题是在我的 Controller 操作中:
public async Task<ActionResult> EditNote(ReleaseNotesModel model)
model.ReleaseNoteTranslations始终包含两个空对象(属性为 null 或 0),即我为此属性设置的默认值。如果我没有设置默认值,那么在弹出编辑器中我将没有任何要编辑此属性的字段。所有其他属性都按预期更新。

让我烦恼的是,如果我使用服务器绑定(bind)而不是 AJAX,那么所有数据都会被正确接收。所以我决定检查两种情况下发送的请求 header 中的数据:
// Using server binding
ReleaseID:300
NoteID:886
ItemType:1
ReleaseNoteTranslations[0].ItemID:886
ReleaseNoteTranslations[0].LanguageID:1
ReleaseNoteTranslations[0].TranslationID:869
ReleaseNoteTranslations[0].Translation:The module is now released!
ReleaseNoteTranslations[1].ItemID:886
ReleaseNoteTranslations[1].LanguageID:2
ReleaseNoteTranslations[1].TranslationID:870
ReleaseNoteTranslations[1].Translation:Le module est maintenant disponible!
NoteID:886

// Using AJAX binding
sort:
group:
filter:
NoteID:886
ReleaseID:300
ReleaseNoteTranslations[0][TranslationID]:869
ReleaseNoteTranslations[0][Translation]:The module is now released!
ReleaseNoteTranslations[0][LanguageID]:1
ReleaseNoteTranslations[0][ItemID]:886
ReleaseNoteTranslations[1][TranslationID]:870
ReleaseNoteTranslations[1][Translation]:Le module est maintenant disponible!
ReleaseNoteTranslations[1][LanguageID]:2
ReleaseNoteTranslations[1][ItemID]:886
ItemType:1

现在我首先注意到的是 objectName[index].PropertyName 的语法。对比 objectName[index][PropertyName]
我想知道这是否是我的问题的原因,如果是这样,有没有办法让我直接操纵发送的数据来修复它?这可能是 Kendo Grid 通过 Ajax 绑定(bind)发送数据的方式中的错误吗?

无论哪种方式,任何帮助将不胜感激!

最佳答案

因此,如果将来有人偶然发现此问题,我联系了 Telerik 支持,他们向我解释说:

The dataSource supports only value types and will not serialize the arrays in the format that is expected by the model binder.



他们还为我提供了一种解决方法,使用 request Data 函数调用 JavaScript 函数,将数据转换为正确的格式。

在 View 中,通过指定要调用的 JavaScript 函数的名称来修改请求函数:
.Create(create => create.Action("AddNote", "ReleaseNotes").Data("serialize"))

然后添加将进行转换的函数:
function serialize(data) {
    for (var property in data) {
        if ($.isArray(data[property])) {
            serializeArray(property, data[property], data);
        }
    }
}
function serializeArray(prefix, array, result) {
    for (var i = 0; i < array.length; i++) {
        for (var property in array[i]) {
            result[prefix + "[" + i + "]." + property] = array[i][property];
        }
    }
}

关于asp.net-mvc - 使用 AJAX 绑定(bind)时创建/更新后具有 IEnumerable 属性的 Kendo Grid 模型未正确更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17495762/

相关文章:

kendo-ui - 仅获取修改或新的 Kendo UI Grid 行以发送到服务器

asp.net-mvc - 在不提交值的情况下将值从 Kendo DDL 传递到 ActionLink/ActionImage

javascript - 更改kendo grid数据源使用JS

jquery - Kendo UI Grid Frozen 列 css - Frozen col 不支持 CSS

asp.net-mvc - 如何检查 NHibernate 版本?

asp.net-mvc - 是否仍支持 MetaWeblog API?

c# - 使用javascript从html文本框中获取值

c# - 从 C# SelectList 中获取文本项

css - 如何删除选定行的悬停效果?

kendo-ui - 如何仅设置剑道网格水平滚动条?