我在表单中同时包含CheckBox
列表和Radio
列表,但是在提交表单时,任一列表的选定选项都不会传递给ActionResult。我错过了什么?
if (Model.IsMultipleChocie)
{
foreach (var Choice in Model.Choices)
{
<li>
@Html.CheckBox("Answers", Choice.Value)
@Html.Label(Choice.Key)
</li>
}
}
else
{
foreach (var Choice in Model.Choices)
{
<li>
@Html.RadioButton("Answers", Choice.Value)
@Html.Label(Choice.Key)
</li>
}
}
public ActionResult ProcessVote(int[] Answers, int UserID, string UserIP, int ID)
答案 0 :(得分:1)
@Html.CheckBox("Answers", Choice.Value)
未设置value
属性,因此您需要使用@Html.CheckBox("Answers", new { value = Choice.Value })
。但是,如下面的评论中所述,@Html.Checkbox()
使用value="false" so you posting back an array which includes
int and bool
值呈现第二个隐藏输入,因此绑定将失败。
手动创建复选框
<input type="checkbox" name="answer" value=@Choice.Value />
或创建一个视图模型来表示您想要显示的内容。例如
public class AnswerVM
{
public int ID { get; set; }
public string Name { get; set; }
public bool IsSelected { get; set; }
}
public class MyVM
{
public bool IsMultipleChoice { get; set; }
public List<AnswerVM> Answers { get; set; }
public int? SelectedAnswer { get; set ; } // for single choice
}
查看
@model MyVM
....
if (Model.IsMultipleChoice)
{
for(int i = 0; i < Model.Answers.Count; i++)
{
@Html.HiddenFor(m => m.Answers[i].ID)
@Html.CheckBoxFor(m => m.Answers[i].IsSelected)
@Html.LabelFor(m => m.Answers[i].IsSelected, Model.Answers[i].Name) // associate label with the checkbox
}
}
else
{
foreach(var answer in Model.Answers)
{
@Html.RadioButtonFor(m => m.SelectedAnswer, @answer.ID)
@Html.DisplayFor(m => m.Answers[i].Name)
}
}
控制器
[HttpPost]
public ActionResult YourMethod(MyVM model)
{
if(model.SelectedAnswer.HasValue)
{
// property SelectedAnswer contains the ID of the selected answer (from radio button)
}
else
{
foreach(AnswerVM answer in model.Answers)
{
if (answer.IsSelected)
{
// answer.ID contains the ID of the checked answers (from checkboxes)
注意:RadioButtonFor()
呈现重复的id
属性,因此您可以为每个属性提供唯一ID(例如基于answer.ID
),以便您可以使用关联的<label for ..>