KendoMVCグリッドとその他の要素を含むフォームを取得して送信しようとしています。
IEnumerable
ビューモデルには、3つの文字列フィールドと1つのコレクション が含まれています。- グリッドはサーバーにバインドされています。グリッドを使用してリストから要素を追加したり削除したりしていませんが、グリッドにはリストアイテムのブール列にマップされたチェックボックスが含まれています。
このフォームを送信するたびに、3つの文字列要素がpostメソッドに返されますが、リストは常にnullです。
データモデルは次のとおりです。
public class Parent
{
public string Field1 { get; set; }
public string Field2 { get; set; }
public string Comments { get; set; }
public IEnumerable<ChildItems> Children { get; set; }
}
public class ChildItems
{
public string ChildField1 { get; set; }
public string ChildField2 { get; set; }
public boolean Include { get; set; }
}
これが私の見解です:
@{
ViewBag.Title = "Index";
}
@model GridInForm.Models.Parent
@using(Html.BeginForm("Save", "Home"))
{
<fieldset>
<legend>Editing Parent</legend>
@Html.LabelFor(parent => parent.Field1)
@Html.EditorFor(parent => parent.Field1)
@Html.LabelFor(parent => parent.Field2)
@Html.EditorFor(parent => parent.Field2)
@Html.LabelFor(parent => parent.Comments)
@Html.EditorFor(parent => parent.Comments)
@(Html.Kendo().Grid(Model.Children)
.Name("Children")
.ToolBar(tools => tools.Create().Text("Add new Children"))
.Editable(editable => editable.Mode(GridEditMode.PopUp).CreateAt(GridInsertRowPosition.Bottom))
.Columns(columns =>
{
columns.Bound(p => p.ChildField1).ClientTemplate("#= ChildField1 #" +
"<input type='hidden' name='ChildField1[#= index(data)#].ChildField1' value='#= Name #' />"
);
columns.Bound(p => p.ChildField2).Hidden().ClientTemplate("#= ChildField1 #" +
"<input type='hidden' name='ChildField1[#= index(data)#].ChildField1' value='#= ChildField1 #' />"
);
columns.Command(command =>
{
// command.Destroy();
command.Edit();
}).Width(100);
})
.DataSource(dataSource => dataSource
.Server()
.Create("Create", "Home")
.Read("Index", "Home")
.Update("Update", "Home")
.Model(model =>
{
model.Id(p => p.ChildField1);
model.Field(p => p.ChildField1).Editable(false);
})
//.ServerOperation(true)
)
)
</fieldset>
<input type="submit" value="Save" />
}
<script>
function index(dataItem) {
alert("bindind");
var data = $("#Products").data("kendoGrid").dataSource.data();
return data.indexOf(dataItem);
}
</script>
フォームを送信すると、親アイテムがビューモデルに戻されIEnumerable
ますが、グリッドのフィールドは常にnullです。
これはこれを行う方法ではありませんか?もしそうなら、このようなことを達成する方法は何ですか?以前のTelerikバージョンでこの問題が発生しましたが、KendoUIでも同じであることがわかります。どんな方向でも大歓迎です。これは長い間問題になっています。