我的Index.cshtml
文件中包含以下代码:
var dataSource = new kendo.data.DataSource({
type: "json",
transport: {
read: {
url: '@Url.Action("ReadTeachers", "EducationPortal")',
dataType: "json"
},
update: {
url: '@Url.Action("UpdateTeachers", "EducationPortal")',
type: "POST"
},
parameterMap: function (data, operation) {
if (operation != "read"){
var result = {};
for (var i = 0; i < data.models.length; i++) {
var teacher = data.models[i];
for (var member in teacher) {
result["teacher[" + i + "]." + member] = teacher[member];
}
}
return result;
} else {
return JSON.stringify(data);
}
}
},
batch: true,
schema: {
model: {
id: "TeacherId",
fields: {
TeacherId: { type: "number" },
FullName: { type: "string" },
IsHeadmaster: { type: "boolean" }
}
}
}
});
$("#teachers").kendoGrid({
dataSource: dataSource,
toolbar: ["create", "save"],
columns: [
{ field: "FullName", title: "Teacher" },
{ field: "IsHeadmaster", title: "Is a Headmaster?", width: "120px" },
{ command: ["destroy"], title: " ", width: "85px" }],
editable: true
});
这是带有“批处理”编辑的标准KendoGrid。编辑和网格本身都可以正常工作,但后端却不能。当“更新”请求通过时,它将转到此控制器方法:
public void UpdateTeachers(string models)
{
// this method will have real code later
Console.Write(models);
}
当我在此处放置断点时,Visual Studio显示models
为null
。像这样:
为什么呢null
?
在您的parameterMap中:function()
而不是使用
return JSON.stringify(data);
利用
return { models: kendo.stringify(data) };
在这里,您的数据已序列化并附加到名称模型,现在此名称模型在您的操作中用作参数名称
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句