gpt4 book ai didi

asp.net-mvc - ASP.NET MVC 复选框组

转载 作者:行者123 更新时间:2023-12-03 05:37:43 24 4
gpt4 key购买 nike

我正在尝试针对 ASP.NET MVC 中缺少“复选框组”的问题制定解决方法。实现此目的的典型方法是使用同名的复选框,每个复选框都有它代表的值。

<input type="checkbox" name="n" value=1 />
<input type="checkbox" name="n" value=2 />
<input type="checkbox" name="n" value=3 />

提交时,它将以逗号分隔请求项“n”的所有值。因此,如果提交时检查了所有三个值,则 Request[“n”] == “1,2,3”。在 ASP.NET MVC 中,您可以使用参数 n 作为数组来接受此帖子。

public ActionResult ActionName( int[] n ) { ... }

以上所有工作正常。我遇到的问题是,当验证失败时,复选框不会恢复到其选中状态。任何建议。

问题代码:(我从默认的asp.net mvc项目开始)

Controller

    public class HomeController : Controller
{
public ActionResult Index()
{ var t = getTestModel("First");
return View(t);
}

[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Index(TestModelView t)
{ if(String.IsNullOrEmpty( t.TextBoxValue))
ModelState.AddModelError("TextBoxValue", "TextBoxValue required.");
var newView = getTestModel("Next");
return View(newView);
}

private TestModelView getTestModel(string prefix)
{ var t = new TestModelView();
t.Checkboxes = new List<CheckboxInfo>()
{ new CheckboxInfo(){Text = prefix + "1", Value="1", IsChecked=false},
new CheckboxInfo(){Text = prefix + "2", Value="2", IsChecked=false}
};
return t;
}
}
public class TestModelView
{ public string TextBoxValue { get; set; }
public List<CheckboxInfo> Checkboxes { get; set; }
}
public class CheckboxInfo
{ public string Text { get; set; }
public string Value { get; set; }
public bool IsChecked { get; set; }
}
}

ASPX

<%
using( Html.BeginForm() ){
%> <p><%= Html.ValidationSummary() %></p>
<p><%= Html.TextBox("TextBoxValue")%></p>
<p><%
int i = 0;
foreach (var cb in Model.Checkboxes)
{ %>
<input type="checkbox" name="Checkboxes[<%=i%>]"
value="<%= Html.Encode(cb.Value) %>" <%=cb.IsChecked ? "checked=\"checked\"" : String.Empty %>
/><%= Html.Encode(cb.Text)%><br />
<% i++;
} %></p>
<p><input type="submit" value="submit" /></p>
<%
}
%>

工作代码

Controller

[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Index(TestModelView t)
{
if(String.IsNullOrEmpty( t.TextBoxValue))
{ ModelState.AddModelError("TextBoxValue", "TextBoxValue required.");
return View(t);
}
var newView = getTestModel("Next");
return View(newView);
}

ASPX

int i = 0;
foreach (var cb in Model.Checkboxes)
{ %>
<input type="checkbox" name="Checkboxes[<%=i%>].IsChecked" <%=cb.IsChecked ? "checked=\"checked\"" : String.Empty %> value="true" />
<input type="hidden" name="Checkboxes[<%=i%>].IsChecked" value="false" />
<input type="hidden" name="Checkboxes[<%=i%>].Value" value="<%= cb.Value %>" />
<input type="hidden" name="Checkboxes[<%=i%>].Text" value="<%= cb.Text %>" />
<%= Html.Encode(cb.Text)%><br />
<% i++;
} %></p>
<p><input type="submit" value="submit" /></p>

当然,可以使用 Html Helpers 完成类似的操作,但这可行。

最佳答案

我不知道如何解决您的问题,但您可以使用以下代码定义复选框:

<%= Html.CheckBox("n[0]") %><%= Html.Hidden("n[0]",false) %>
<%= Html.CheckBox("n[1]") %><%= Html.Hidden("n[1]",false) %>
<%= Html.CheckBox("n[2]") %><%= Html.Hidden("n[2]",false) %>

需要隐藏字段,因为如果未选中复选框,表单不会发送任何值。对于隐藏字段,它会发送 false。

您的发布方法将是:

[HttpPost]
public ActionResult Test(bool[] n)
{
return View();
}

它可能不是最佳的,我愿意接受评论,但它有效:)

编辑

扩展版本:

<%= Html.CheckBox("n[0].Checked") %><%= Html.Hidden("n[0].Value",32) %><%= Html.Hidden("n[0].Checked",false) %>
<%= Html.CheckBox("n[1].Checked") %><%= Html.Hidden("n[1].Value",55) %><%= Html.Hidden("n[1].Checked",false) %>
<%= Html.CheckBox("n[2].Checked") %><%= Html.Hidden("n[2].Value",76) %><%= Html.Hidden("n[2].Checked",false) %>

您的发布方法将是:

[HttpPost]
public ActionResult Test(CheckedValue[] n)
{
return View();
}

public class CheckedValue
{
public bool Checked { get; set; }
public bool Value { get; set; }
}

我在没有使用 VS 的情况下编写了它,因此可能需要很少的修改。

关于asp.net-mvc - ASP.NET MVC 复选框组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2067786/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com