1

我有以下模型类(我首先使用 EF 代码来生成表)。

public class MyClass
{
    ....
    [Required, ForeignKey("Address")]
    public int Address1Id { get; set; }
    virtual public Address Address1 { get; set; }
    [Required, ForeignKey("Address")]
    public int Address12d { get; set; }
    virtual public Address Address2 { get; set; }
    [Required, ForeignKey("Address")]
    public int Address3Id { get; set; }
    virtual public Address Address3 { get; set; }
    ....
}
public class Address { .... }

我希望创建视图MyClass显示所有地址字段,并且在保存MyClass. 但是脚手架为地址生成了一个 DropDownList 框。如何修改代码,使其像这些地址字段MyClass直接编码在类中一样,让控制器将地址保存在表AddressAddressID表中MyClass

    <div class="editor-label">
        @Html.LabelFor(model => model.Address1Id, "Address")
    </div>
    <div class="editor-field">
        @Html.DropDownList("Address1Id", String.Empty)
        @Html.ValidationMessageFor(model => model.Address1Id)
    </div>

更新: 我尝试创建以下 ViewModel,但脚手架抱怨类中没有定义键。

public class DealViewModel
{
    public Deal Deal { get; set; }
    public Address Address { get; set; }
}
4

2 回答 2

1

听起来您在问如何在 MVC 中为编辑/创建视图展平模型。您不想先创建一个 Person,然后再创建一个 Address,而是在一个屏幕中创建它。如果这就是您要问的,是的,您可以做到!事实上,做你想做的事情就像将你的创建视图更改为类似的东西一样简单:

<h3>Address 1</h3>
@Html.EditorFor(x => x.Address1)
<h3>Address 2</h3>
@Html.EditorFor(x => x.Address2)
...etc

默认情况下,MVC 足够聪明,可以猜测您的“编辑器”Address应该是什么样子。字符串的文本字段、布尔值的复选框等。如果您的[HttpPost]控制器看起来像这样:

[HttpPost]
public ActionResult Create(Person person)
{
    if (ModelState.IsValid)
    {
        var context = new AppDbContext();
        context.People.Add(person);
        context.SaveChanges();
        return RedirectToAction("Index");
    }
    return View(personViewModel);
}

如果您person在调试器中检查,您应该会看到Address所有属性都已填写。是的,MVC ModelBinder 就是这么聪明!你不应该做任何其他事情。

注意:随着项目的进展,您的数据模型不可避免地会变得更加复杂,您可能会遇到从控制器到视图来回传递模型对象的问题。我强烈建议遵循使用 ViewModel 的模式,它是代表视图“模型”的普通对象,也就是说,它应该捆绑所有进出客户端的数据。这将允许您展平数据模型并仅包含您实际需要的字段。对于这个特定示例,您可能不需要使用此模式,但它在将来会有所帮助。

希望这可以帮助!

于 2013-02-18T04:08:29.183 回答
1

您的外键属性不正确:

[Required, ForeignKey("Address1")]
...
[Required, ForeignKey("Address2")]
...
[Required, ForeignKey("Address3")]
...

Address12d我猜是错字)

于 2013-02-17T10:41:28.420 回答