1

次のような単純なモデルがあります。

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 を使用すると、フィールドは正しく設定されます。

問題は何ですか?

4

1 に答える 1