我在ASP MVC(Razor)中有一个表单,在这个表单中我有一个Textboxes ...和一个<select>
我希望将这个选择的选定选项(值)传送到控制器,如其他信息。文本框正确传输到控制器,并且在数据库中。
我在数据库中有一个名为NumberParticipant的字段,我希望通过我的Create控制器传输数据库:
我的代码:
@using (Html.BeginForm())
{
<div class="form-group">
@Html.LabelFor(model => model.LocalNumber, new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.EditorFor(model => model.LocalNumber, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.LocalNumber)
</div>
</div>
<div class="col-md-10">
<select class="form-control" id="numberParticipant">
<option value=""></option>
<option value="2">2</option>
<option value="3">3</option>
<option value="4">4</option>
<option value="5">5</option>
</select>
</div>
<input type="submit" value="Create" class="btn btn-default" />
}
答案 0 :(得分:5)
使用MVC DropDownList帮助程序可以避免写出所有的html。这是一个在视图中设置选项值的示例。
<div class="col-md-10">
@Html.DropDownListFor(model => model.NumberParticipant,
new SelectList(new []
{ new {value="",text=""},
new {value="2",text="2"},
new {value="3",text="3"},
new {value="4",text="4"},
new {value="5",text="5"}
},"value","text"), new { htmlAttributes = new { @class = "form-control" }})
</div>
最佳做法是将SelectList类型的属性添加到模型类中,并在那里设置可能的选项。然后,您可以在助手中引用新属性,如下所示:
<div class="col-md-10">
@Html.DropDownListFor(model => model.NumberParticipant,
Model.MySelectList, new { htmlAttributes = new { @class = "form-control" }})
</div>