1

我有两个模型,我想在数据库中插入一行,并在 DropDownList 中填充外键关系。Item 模型的数据插入没有问题,但 ManufacturerID 没有插入(它插入 null)。我找不到原因。更新:将项目上传到: http: //mvcapplication2.codeplex.com/

<div class="editor-label">
   @Html.LabelFor(model => model.ManufacturerID,"Manufacturer")
</div>

<div class="editor-field">
   @Html.DropDownList("ManufacturerID",string.Empty)
   @Html.ValidationMessageFor(model => model.ManufacturerID)
</div>

public class Item
{
   public int ItemID { get; set; }
   public string Serial { get; set; }
   public string ItemName { get; set; }
   public int? ManufacturerID { get; set; }
   public Manufacturer Manufacturer { get; set; }
}

public class Manufacturer
{
   public int ManufacturerID { get; set; }
   public string ManufacturerName { get; set; }
   public List<Item> Items { get; set; }
}

public ActionResult Create()
{
   ViewBag.ManufacturerID = new SelectList(db.Manufacturers, "ManufacturerID", "ManufacturerName");
   return View();
} 

[HttpPost]
public ActionResult Create(Item ıtem)
{
   if (ModelState.IsValid)
   {
      db.Items.Add(ıtem);
      db.SaveChanges();
      return RedirectToAction("Index"); 
   }

   return View(ıtem);
}
4

3 回答 3

3

我宁愿不在视图中使用域模型。我会创建一些特定于视图的视图模型。此外,要从操作方法(例如:下拉列表)传输数据,我将使用强类型方法,而不是动态 viewbag/viewdata 方法。

创建视图模型类

public class CreateItemVM
{
  public string SerialNumber { set;get;}
  public int SelectedManufactureID { set;get;}
  public List<SelectListItem> Manufacturers { set;get;}
  public CreateItemVM()
  {
     Manufacturers =new List<SelectListItem>();
  }     
}

现在在您的 GET 操作方法中,创建我们的视图模型的对象,初始化相关值并发送到视图。

public ActionResult Create()
{
  var vm=new CreateItemVM();
  vm.Manufacturers=GetManufacturerList();
  return View(vm);
}
private List<SelectListItem> GetManufacturerList()
{
    List<SelectListItem> manuList=new List<SelectListItem>();
    manuList=(from p in  db.Manufacturers
                   select new SelectListItem { 
                                               Value=p.ID.ToString(),
                                               Text=p.Name}
              ).ToList();
    return manuList;
}

现在在我们的视图中,我们的视图模型是强类型的,

@model CreateItemVM
@using(Html.Beginform())
{
  @Html.DropDownListfor(x=>x.SelectedManufactureID ,
                                      Model.Manufacturers,"select")
  <input type="submit" />
}

最后在我们的 POST 操作方法中,我们将从发布的视图模型中读取值并将其分配为我们的域对象的属性值并保存它。选定的制造商 ID 值将在SelectedManufactureID我们的视图模型的属性中。

[HttpPost]
public ActionResult Create(CreateItemVM model)
{
  if(ModelState.IsValid)
  {
     Item domainObject=new Item();
     domainObject.ManufacturerID =model.SelectedManufactureID ;
     //set other relevant properties also
      db.Items.Add(ıtem);
      db.SaveChanges();
      return RedirectToAction("Index");
  } 
  // reload the dropdown before returning to the view
  model.Manufacturers=GetManufacturerList();
  return View(model);   
}
于 2013-01-25T21:54:01.937 回答
1

尝试使关系更明确,使属性虚拟并添加属性:

public class Item
{
    ...
    [ForeignKey("Manufacturer")]
    public int? ManufacturerID { get; set; }
    public virtual Manufacturer Manufacturer { get; set; }
}

public class Manufacturer
{
    ...
    public virtual List<Item> Items { get; set; }
}

编辑:

您可以使用更紧密的方式来构建下拉列表:

@Html.DropDownListfor(x=>x.SelectedManufactureID ,
                                  ViewBag.ManufacturerID as SelectList,"Choose one")

编辑2:

更好的方法是为视图制作一个特定的模型(称为 ViewModel)来表示数据并像@Shyju 所说的那样构建视图。

于 2013-01-25T21:15:37.047 回答
0

发现了问题。我发送到视图的 Viewbag 应该命名为 ManufacturerID,我发送的是 Manufacturers,尽管它填充了下拉列表,但不知何故它不匹配。

于 2013-01-26T23:04:13.650 回答