在ASP.NET MVC 3中,在Html.BeginForm()中传递DropDownList的SelectedValue

3
这是我的视图代码:
@using(Html.BeginForm(new { SelectedId = /*SelectedValue of DropDown*/ })) {

 <fieldset>

     <dl>
       <dt>
           @Html.Label(Model.Category)
       </dt>
       <dd>
        @Html.DropDownListFor(model => Model.Category, CategoryList)
       </dd>
    </dl>

 </fieldset>
 <input type="submit" value="Search" />


}

根据代码显示,我需要将下拉菜单(dropdown)选择的值传递给 BeginForm() Html 助手中的操作。你有什么建议吗?


1
在渲染时,您如何知道所选的值? - Tuan
@Tutan 这是我的问题,是否有任何答案? - Saeid
1个回答

16

在表单提交时,所选的值会被传递,因为下拉列表由 <select> 元素表示。你只需要调整你的视图模型,使其有一个名为SelectedId的属性,然后将其绑定到下拉列表即可:

@using(Html.BeginForm() )
{
    <fieldset>
        <dl>
            <dt>
                @Html.LabelFor(x => x.SelectedId)
            </dt>
           <dd>
                @Html.DropDownListFor(x => x.SelectedId, Model.CategoryList)
           </dd>
        </dl>
    </fieldset>

    <input type="submit" value="Search" />
}

这假设了以下视图模型:

public class MyViewModel
{
    [DisplayName("Select a category")]
    public int SelectedId { get; set; }

    public IEnumerable<SelectListItem> CategoryList { get; set; }
}

这将由您的控制器处理:

public ActionResult Index()
{
    var model = new MyViewModel();
    // TODO: this list probably comes from a repository or something
    model.CategoryList = new[]
    {
        new SelectListItem { Value = "1", Text = "category 1" },
        new SelectListItem { Value = "2", Text = "category 2" },
        new SelectListItem { Value = "3", Text = "category 3" },
    };
    return View(model);
}

[HttpPost]
public ActionResult Index(MyViewModel model)
{
    // here you will get the selected category id in model.SelectedId
    return Content("Thanks for selecting category id: " + model.SelectedId);
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接