5

假设我有这样的模型:

public class Foo {
    public List<Bar> Bars { get; set; }
    public string Comment { get; set; }
}

public class Bar {
    public int Baz { get; set; }
}

我想要一个Foo允许用户编辑Bar项目的视图。但有一个问题:我希望Bar编辑由部分视图处理。

@model Web.ViewModels.Foo

@using(Html.BeginForm()) {
    @Html.Partial("_EditBars", Model.Bars)
    @Html.TextAreaFor(m => m.Comment)
    ...
}

_EditBars部分视图类似于:

@model List<Web.ViewModels.Bar>

@for (int i = 0; i < Model.Count; i++) {
    @Html.EditorFor(m => Model[i].Baz)
}

我希望这个模型绑定到我的动作,它看起来像:

[HttpPost]
public ActionResult Edit(Foo foo) {
    // Do stuff
}

不幸的是,这是我发布的数据,它没有模型绑定Bars属性:

[1].Baz=10&[0].Baz=5&Comment=bla

这不起作用是有道理的,因为它缺少Bars前缀。如果我理解正确,我需要它是这样的:

Bars[1].Baz=10&Bars[0].Baz=5&Comment=bla

所以,我尝试了这种方法

@Html.Partial(
    "_EditBars",
    Model.Bars,
    new ViewDataDictionary(ViewData)
    {
        TemplateInfo = new TemplateInfo
        {
            HtmlFieldPrefix = "Bars"
        }
    }) 

但这也行不通。有了这个,我得到:

Bars.[1].Baz=10&Bars.[0].Baz=5&Comment=bla

我认为由于额外的时间段(Bars.[1]vs. Bars[1]),这不起作用。我能做些什么来获得我想要的结果吗?

注意:这是对我的实际情况的过度简化。我认识到,有了这么简单的东西,在我看来,最好的方法可能是使用EditorTemplateforBar和循环EditorFor。如果可能的话,我想避免这种解决方案。

4

1 回答 1

4

由于您不想使用EditorTemplatefor Bar,因此您的方案的解决方案可能是:

将“_EditBars”部分视图的@model 类型更改为Foo,视图应如下所示:

@model Foo

@if (Model.Bars != null)
{
    for (int i = 0; i < Model.Bars.Count; i++)
     {
         @Html.EditorFor(m => Model.Bars[i].Baz)
     }
}

(最好将部分视图的名称更改为'_EditFooBars'

希望这可以帮助。

于 2013-03-09T10:04:58.543 回答