次のような単純なモデルがあります。
public class MyRecordModel
{
public MyRecordModel()
{
}
public string Name{ get; set; }
public string Surname { get; set; }
public string Email { get; set; }
}
次に、その編集モデルがあります。
public partial class MyRecordEditModel
{
public MyRecordEditModel()
{
this.MyRecord= new MyRecordModel();
}
public MyRecordModel MyRecord { get; set; }
}
コントローラーも非常に単純です。
public ActionResult MyRecordAdd()
{
var model = new MyRecordEditModel();
return View(MYROUTE, model);
}
[HttpPost]
public ActionResult MyRecordAdd(MyRecordEditModel model)
{
if (ModelState.IsValid)
{
//Save to db
}
}
そして、これは私の見解です:
@model MyRecordEditModel
@using (Html.BeginForm())
{
@Html.HiddenFor(model => model.MyRecord.Id)
<table>
<tr>
<td>
@Html.LabelFor(model => model.MyRecord.Name):
</td>
<td>
@Html.EditorFor(model => model.MyRecord.Name)
@Html.RequiredHint()
</td>
</tr>
<tr>
<td>
@Html.LabelFor(model => model.MyRecord.Surname)
</td>
<td>
@Html.EditorFor(model => model.MyRecord.Surname)
@Html.RequiredHint()
</td>
</tr>
<tr>
<td>
@Html.LabelFor(model => model.MyRecord.Email):
</td>
<td>
@Html.EditorFor(model => model.MyRecord.Email)
@Html.RequiredHint()
</td>
</tr>
</table>
<div class="buttons">
<input type="submit" value="@T("Common.Save")" />
</div>
}
ビューから返されるモデルは常に空です。ただし、モデルの代わりに FormCollection を使用すると、フィールドは正しく設定されます。
問題は何ですか?