如何在MVC 5中使用DropdownListFor在多个DropDownList中选择值

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在MVC 5中使用DropdownListFor在多个DropDownList中选择值相关的知识,希望对你有一定的参考价值。

我有这个型号:

public class CampoTipoDocumentoViewModel
{
    public int TipoDocumentoId { get; set; }

    public string[] CamposId { get; set; }

    private List<MiddleTier.Models.ICampo> _todosCampos;
    public IEnumerable<SelectListItem> TodosCampos
    {
        get
        {
            foreach (var campo in _todosCampos)
                yield return new SelectListItem { Text = campo.Nombre, Value = campo.Id.ToString() };
        }
    }  

    public void SetFields(List<MiddleTier.Models.ICampo> campos)
    {
        _todosCampos = campos;
    }
}

在控制器中,为CamposId属性分配了必须在视图中选择的元素。

Controller还调用SetFields方法将_todosCampos填充到系统中的整个记录​​列表中。

我们的想法是创建一个带有SELECT的视图,该视图最初选择了一些记录。

这是我的看法:

@html.DropDownListFor(m => m.CamposId, Model.TodosCampos, new { @class = "form-control", multiple = "multiple", width = "100%" })

事实是HTML SELECT元素是使用列表创建的,但没有选择任何选项。

例如,如果_todosCampos包含:

Text = "One", Value = "1"
Text = "Two", Value = "2"
Text = "Three", Value = "3"
Text = "Four", Value = "4"

和CamposId包含:

Array of "2", "4"

我需要视图创建一个带有这4个选项的SELECT,并且最初选择选项2和4。

我怎样才能做到这一点?

谢谢Jaime

答案

为了将<select>元素与multiple="multiple"属性一起使用,您需要声明List<string>属性:

public List<string> CamposId { get; set; }

然后使用ListBoxFor助手而不是DropDownListFor

@Html.ListBoxFor(m => m.CamposId, Model.TodosCampos, new { @class = "form-control", multiple = "multiple", width = "100%" })

如果要设置默认选择的某些选项值,则将Selected属性设置为SelectListItem

public IEnumerable<SelectListItem> TodosCampos
{
    get
    {
        foreach (var campo in _todosCampos)
        {
            // assumed you have 'campo.IsDefault' which is boolean property 
            yield return new SelectListItem 
            { 
                Text = campo.Nombre, 
                Value = campo.Id.ToString(), 
                Selected = campo.IsDefault // set default selected values
            };
        }
    }
}  

注意:通常ID属性包含整数值,您可以根据数据库中的实际ID数据类型尝试List<int> CamposId

以上是关于如何在MVC 5中使用DropdownListFor在多个DropDownList中选择值的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Asp.Net 5 (MVC 6) 中使用实体框架 6.x

如何在 MVC 5 应用程序中存储用户数据? (使用 Windows 身份验证)

如何在MVC 5中使用DropdownListFor在多个DropDownList中选择值

如何在 Asp.Net mvc 5 的 grid.mvc 中添加两个按钮

如何使用 MVC 5 在基于令牌的身份验证中检查用户是不是从控制器登录?

MVC 5 - 如何首先使用 EF 代码更新关系表