Asp.net mvc 4 MVC-由于ViewModel而导致外键错误?

Asp.net mvc 4 MVC-由于ViewModel而导致外键错误?,asp.net-mvc-4,viewmodel,foreign-key-relationship,Asp.net Mvc 4,Viewmodel,Foreign Key Relationship,我正在创建Employee类的视图模型,并使用EmployeeViewModel强键入我的创建视图。将来,我将在视图模型中添加许多类。但问题是我的外键出现了性别错误。可能是我在创建控制器中绑定了错误的值。下面是我的代码: 创建控制器: public ActionResult Create() { ViewBag.GenderId = new SelectList(db.Genders, "Id", "Name"); return View(); } [HttpPost] [Valida

我正在创建Employee类的视图模型,并使用EmployeeViewModel强键入我的创建视图。将来,我将在视图模型中添加许多类。但问题是我的外键出现了性别错误。可能是我在创建控制器中绑定了错误的值。下面是我的代码:

创建控制器:

public ActionResult Create()
{
  ViewBag.GenderId = new SelectList(db.Genders, "Id", "Name");
  return View();
}

[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult Create(EmployeeViewModel employeeModel)
{
  if (ModelState.IsValid)
  {
     db.Employees.Add(employeeModel.Employee);
     db.SaveChanges();
     return RedirectToAction("Index");
  }

  ViewBag.GenderId = new SelectList(db.Genders, "Id", "Name", employeeModel.Employee.GenderId);
  return View(employeeModel);
}
创建视图:

@model WebApplication2.EmployeeViewModel

@using (Html.BeginForm()) 
{

@Html.AntiForgeryToken()

<div class="form-horizontal">
    <h4>Employee</h4>
    <hr />
    @Html.ValidationSummary(true, "", new { @class = "text-danger" })
    <div class="form-group">
        @Html.LabelFor(model => model.Employee.Name, htmlAttributes: new { @class = "control-label col-md-2" })
        <div class="col-md-10">
            @Html.EditorFor(model => model.Employee.Name, new { htmlAttributes = new { @class = "form-control" } })
            @Html.ValidationMessageFor(model => model.Employee.Name, "", new { @class = "text-danger" })
        </div>
    </div>

    <div class="form-group">
        @Html.LabelFor(model => model.Employee.GenderId, "GenderId", htmlAttributes: new { @class = "control-label col-md-2" })
        <div class="col-md-10">
            @Html.DropDownList("GenderId", null, htmlAttributes: new { @class = "form-control" })
            @Html.ValidationMessageFor(model => model.Employee.GenderId, "", new { @class = "text-danger" })
        </div>
    </div>

    <div class="form-group">
        <div class="col-md-offset-2 col-md-10">
            <input type="submit" value="Create" class="btn btn-default" />
        </div>
    </div>
</div>
}
视图模型:

public class EmployeeViewModel
{
    public Employee Employee { get; set; }
}

视图模型不包含作为数据模型的属性。如果您使用的是视图模型,那么就永远不会使用
ViewBag
[Bind]
属性!当你创建一个与你的模型没有关系的dropdownlist时(你这么做),当你提交时,它将是它的默认值。太棒了!我在视图模型中声明了属性,并删除了视图包和绑定。按预期工作。视图模型不包含作为数据模型的属性。如果您使用的是视图模型,那么就永远不会使用
ViewBag
[Bind]
属性!当你创建一个与你的模型没有关系的dropdownlist时(你这么做),当你提交时,它将是它的默认值。太棒了!我在视图模型中声明了属性,并删除了视图包和绑定。按预期工作。
public class EmployeeViewModel
{
    public Employee Employee { get; set; }
}