【问题标题】:CheckboxFor not binding with nested objectsCheckboxFor 不绑定嵌套对象
【发布时间】:2011-10-10 12:53:51
【问题描述】:

当在模型中嵌套的对象中定义属性时,CheckBoxFor 没有界限?

这是一个例子。我有一个包含 List<Star> 属性的 SearchOptions 模型。每个Star 都有一个数字、一个名称和一个bool 应该有界的属性:

public class SearchOptions
{

    public SearchOptions()
    {
        // Default values
        Stars = new List<Star>()
        {
            new Star() {Number=1, Name=Resources.Home.Index.Star1,
                IsSelected=false},
            new Star() {Number=2, Name=Resources.Home.Index.Star2,
                IsSelected=false},
            new Star() {Number=3, Name=Resources.Home.Index.Star3,
                IsSelected=true},
            new Star() {Number=4, Name=Resources.Home.Index.Star4,
                IsSelected=true},
            new Star() {Number=5, Name=Resources.Home.Index.Star5,
                IsSelected=true},
        };
    }

    public List<Star> Stars { get; set; }

}

在我的强类型视图(SearchOptions)中,我循环了Stars 属性:

@using (Html.BeginForm("Do", "Home"))
{
    <fieldset>
        <legend>@MVC3TestApplication.Resources.Home.Index.Search</legend>
        @{ 
            foreach (Star s in Model.Stars)
           {
                @Html.CheckBoxFor(m => s.IsSelected)
                <label>@s.Name</label>

           }}
    </fieldset>
    <input type=submit value="Invia" />
}

控制器的(相关部分)是:

    public ActionResult SearchOptions()
    {
        return View(new SearchOptions());
    }

    [HttpPost]
    public ActionResult Do(SearchOptions s)
    {
        // Do some stuff
        return View("SearchOptions", s);
    }

【问题讨论】:

  • 您的代码看起来不错 - 实际上有什么问题?您是通过View(model) 传递模型吗?
  • Do (SearchOptions s) 显示 s 具有旧(默认)值,即使我选中/取消选中所有复选框。感谢您的帮助,
  • 啊。在这种情况下,原因是嵌套属性。 CheckBoxFor() 的输出将其名称值设置为 s.IsSelected 而不是 Model.Star[].IsSelected。我会看看我能做什么,否则其他人会在我面前发布答案:)

标签: asp.net-mvc asp.net-mvc-3 razor binding checkbox


【解决方案1】:

这是因为您访问 CheckBoxFor 表达式中的属性的方式。

@for (int i = 0; i < Model.Stars.Count(); i++) { 
    @Html.CheckBoxFor(m => m.Stars[i].IsSelected)
    <label>@Model.Stars[i].Name</label>
}

这应该适合你。

这是不同方法的输出:

//using the for loop
<input id="Stars_2__IsSelected" name="Stars[2].IsSelected" type="checkbox" value="true" />

//using the foreach
<input checked="checked" id="s_IsSelected" name="s.IsSelected" type="checkbox" value="true" />

您会注意到 foreach 不包含与其在进行模型绑定时匹配的正确名称。

【讨论】:

  • 有效。但是有一个奇怪的问题:在 POST 标签得到一个空值之后。我刚刚使用 &lt;label&gt; 没有将 Model.Stars[i].Name 绑定到某个输入字段。你知道为什么吗? 编辑:使用 Html.HiddenFor 解决。但这是正确的方法吗?为要绑定的对象的每个属性编写一个 HiddenFor 真是太费劲了……
  • 原因是Html 助手使用列表项中的帖子值。因为Name 属性的帖子值是null,所以重用时它们将为空(因为它们将覆盖默认值)。除了在输出之前重新填充名称和数字之外,我不确定您还能做什么。
  • 据我所知,它不适用于列表或数组属性,我可能是错的。
  • 有没有办法用 foreach 循环而不是 for 循环来做到这一点?
猜你喜欢
  • 2014-05-08
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-08-27
  • 1970-01-01
相关资源
最近更新 更多