2

我完全不明白这个简单的概念如何似乎不起作用。我有一个 ViewModel、一个控制器和一个视图...

这是我的基本视图模型

public class CreateProfessionalEducationViewModel
{

    public Models.ProfessionalEducation ProfessionalEducation;

    public int ConsultantId;

    public CreateProfessionalEducationViewModel() {} // parameterless constr

}

这些是我的 2 个控制器方法

 public ActionResult Create(int id)
    {
        var viewModel = new CreateProfessionalEducationViewModel
        {
            ConsultantId = id
        };

        return View(viewModel);
    }

    //
    // POST: /ProfessionalEducation/Create

    [HttpPost]
    [ValidateAntiForgeryToken]
    public ActionResult Create(CreateProfessionalEducationViewModel collection)
    {
        if (ModelState.IsValid)
        {
            //db.ProfessionalEducations.Add(professionaleducation);
            db.SaveChanges();
            return RedirectToAction("Index");
        }

        return View();
    }

和我的看法...

@model Axxes_Virtual_Resume_MVC.ViewModel.ProfessionalEducation.CreateProfessionalEducationViewModel
@using (Html.BeginForm("Create", "ProfessionalEducation")) {
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)

<fieldset>
    <legend>ProfessionalEducation</legend>

    <div class="editor-label">
        @Html.LabelFor(model => model.ProfessionalEducation.Year)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.ProfessionalEducation.Year)
        @Html.ValidationMessageFor(model => model.ProfessionalEducation.Year)
    </div>

    <div class="editor-label">
        @Html.LabelFor(model => model.ProfessionalEducation.Title)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.ProfessionalEducation.Title)
        @Html.ValidationMessageFor(model => model.ProfessionalEducation.Title)
    </div>
    @Html.HiddenFor(model => model.ConsultantId)
    <p>
        <input type="submit" value="Create" />
    </p>
</fieldset>
}

由于某些奇怪的原因,我的 ConsultantId 为 0 并且当我的 ViewModel 中的 ProfessionalEducation 为空时,在我的控制器中回发到 HttpPost Create 方法时。

这应该很基本,我忘记了什么?

提前致谢!!

4

3 回答 3

1

主要问题是,DefaultModelBinder(从 重建视图模型的东西HttpFormCollection)的疯子适用于属性而不是变量。

如果我没记错的话,我相信如果您在 Viewmodel 中使用类似的内部对象并直接在 View 中访问它们的属性,那么默认模型绑定器就不能很好地工作。

尝试这样的事情:

public class CreateProfessionalEducationViewModel
{
    public int ConsultantId  { get; set; }

    public int ProfessionalEducationYear { get; set; }

    public string ProfessionalEducationTitle  { get; set; }
}

当然,对于视图

@model Axxes_Virtual_Resume_MVC.ViewModel.ProfessionalEducation.CreateProfessionalEducationViewModel
@using (Html.BeginForm("Create", "ProfessionalEducation")) {
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)

<fieldset>
    <legend>ProfessionalEducation</legend>

    <div class="editor-label">
        @Html.LabelFor(model => model.ProfessionalEducationYear )
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.ProfessionalEducationYear )
        @Html.ValidationMessageFor(model => model.ProfessionalEducationYear )
    </div>

    <div class="editor-label">
        @Html.LabelFor(model => model.ProfessionalEducationTitle)
    </div>
    <div class="editor-field">
        @Html.EditorFor(model => model.ProfessionalEducationTitle)
        @Html.ValidationMessageFor(model => model.ProfessionalEducationTitle)
    </div>
    @Html.HiddenFor(model => model.ConsultantId)
    <p>
        <input type="submit" value="Create" />
    </p>
</fieldset>
}

作为一项规则,尽量避免在您的 ViewModel 中引用模型对象(但这只是设计规则)

于 2013-09-05T13:15:42.603 回答
1

在我的 ViewModel 中使用属性而不是字段为我修复了它。

感谢任何人的努力。

于 2014-01-14T13:35:55.790 回答
0

标签的名称属性必须是“ProfessionalEducation.Year”或“ProfessionalEducation.Title”,以便默认绑定起作用。所以使用这个:

@Html.TextBox("ProfessionalEducation.Year")

代替

@Html.EditorFor(model => model.ProfessionalEducation.Year)

Title 属性也是如此。您可以在这篇有用的文章中阅读有关 ASP.NET MVC 模型绑定的更多信息:http: //dotnetslackers.com/articles/aspnet/Understanding-ASP-NET-MVC-Model-Binding.aspx

于 2013-09-05T13:35:35.443 回答