注意:这个问题已经超过9年了!

您最好的选择是搜索更新的问题,或者搜索下面的答案,寻找您特定的MVC版本,因为这里的许多答案现在已经过时了。

如果你确实找到了适合你的版本的答案,请确保答案包含了你正在使用的MVC版本。 (原来的问题从下面开始)


这对我来说似乎有点奇怪,但据我所知,这就是你怎么做的。

我有一个对象集合,我希望用户从中选择一个或多个对象。这对我来说是“带复选框的表单”。我的对象没有任何“选定”的概念(它们是通过反序列化wcf调用形成的基本POCO)。所以,我这样做:

public class SampleObject{
  public Guid Id {get;set;}
  public string Name {get;set;}
}

在视图中:

<%
    using (Html.BeginForm())
    {
%>
  <%foreach (var o in ViewData.Model) {%>
    <%=Html.CheckBox(o.Id)%>&nbsp;<%= o.Name %>
  <%}%>
  <input type="submit" value="Submit" />
<%}%>

并且,在控制器中,这是我能看到的唯一方法来找出用户检查了什么对象:

public ActionResult ThisLooksWeird(FormCollection result)
{
  var winnars = from x in result.AllKeys
          where result[x] != "false"
          select x;
  // yadda
}

首先,它很怪异,其次,对于用户选中的那些项,FormCollection将其值列出为“true false”而不仅仅是true。

显然,我遗漏了一些东西。我认为这是基于这样的想法构建的,即在html表单中所作用的集合中的对象是使用UpdateModel()或通过ModelBinder更新的。

但我的对象并不是为此而设置的;这意味着这是唯一的办法吗?还有别的办法吗?


当前回答

这个问题也出现在1.0版中。Html.Checkbox()导致添加另一个隐藏字段,其名称/id与原始复选框相同。当我尝试使用document.GetElemtentsByName()加载复选框数组时,您可以猜到事情是如何变得混乱的。这很奇怪。

其他回答

您还应该使用<label for="checkbox1">Checkbox 1</label>,因为这样人们就可以单击标签文本以及复选框本身。它也更容易设置样式,至少在IE中,当你通过页面的控件时,它会被突出显示。

<%= Html.CheckBox("cbNewColors", true) %><label for="cbNewColors">New colors</label>

这不仅仅是一件‘哦,我可以做到’的事情。这是一个显著的用户体验增强。即使不是所有用户都知道他们可以点击标签,很多人也会。

这是我在使用Html.CheckBox(…

Replace("true,false","true").Split(',')

选中4个箱子,不选中,不选中,再选中它 真的,假的,假的,假的,真的,假的 成 真的,假的,假的,真的。 这正是我所需要的

HtmlHelper添加了一个隐藏输入来通知控制器未检查状态。 所以要有正确的检查状态:

bool bChecked = form[key].Contains("true");

这个问题也出现在1.0版中。Html.Checkbox()导致添加另一个隐藏字段,其名称/id与原始复选框相同。当我尝试使用document.GetElemtentsByName()加载复选框数组时,您可以猜到事情是如何变得混乱的。这很奇怪。

<input type = "checkbox" name = "checkbox1" /> <label> Check to say hi.</label>

来自控制器:

    [AcceptVerbs(HttpVerbs.Post)]
    public ActionResult Index(FormCollection fc)
    {

         var s = fc["checkbox1"];

         if (s == "on")
         {
             string x = "Hi";
         }
    }