如何将模型从数据库转移到编辑页面?

时间:2019-02-17 04:16:51

标签: c# asp.net-mvc

我的输入模型由NewForm组成,其中有许多字段

public class NewForm
    {
         [Key]
        public int Id { get; set; }
        public string HeadForm { get; set; }

        public List<Field> Fields { get; set; }   
    }

    public class Field
    {
        public int Id { get; set; }
        public bool Check { get; set; }
        public string HeadField { get; set; }
    }

我想从基中获取值并对其进行编辑,但是Model.Fields.Count抛出异常。尽管显示字符串“ HeadForm”。列表不显示。 编辑页面:

@model EditFormApplication.Models.NewForm

@using (Html.BeginForm("Edit", "Home", FormMethod.Post))
{
    @Html.TextBoxFor(model => model.HeadForm)
    <h5>Fields:</h5><br>
        @for ( var i = 0; i< Model.Fields.Count; i++) {
          @Html.TextBoxFor(model => model.Fields[i].HeadField)                     
          @Html.CheckBoxFor(model => model.Fields[i].Check)
        }
        <input type="button" value="Add Field" onclick="addField(this);">
        <input type="submit"value="Save">
}

例如,我正在按ID = 3键入数据。 控制器:

 public ActionResult CreateForm(NewForm model)
    {
        using (NewFormContext db = new NewFormContext())
        {
           db.NewForms.Add(model);
           db.SaveChanges();
           return RedirectToAction("Edit");
         }
     }

  public ActionResult Edit()
    {
        using (NewFormContext db = new NewFormContext()) { 
            var model = db.NewForms.Find(3);

        return this.View(model);
    }
    }

使用“代码优先”和“一对多”

1 个答案:

答案 0 :(得分:1)

在执行Model.Fields来分配要返回到视图的模型时,类似db.NewForms.Find()属性的声音仍包含null,这表明EF尚未创建依赖集合。据我所知,您应该在实体类的无参数构造函数中添加集合实例定义:

public class NewForm
{
    public NewForm()
    {
        // instantiate list here
        Fields = new List<Field>();
    }

    [Key]
    public int Id { get; set; }
    public string HeadForm { get; set; }

    public List<Field> Fields { get; set; }   
}

或者,如果您使用的是延迟加载,请将属性标记为virtual,以便在必要时让EF实例化集合:

public virtual List<Field> Fields { get; set; } 

相关问题:

EF codefirst : Should I initialize navigation properties?