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

时间:2018-11-28 22:49:30

标签: c# asp.net-mvc asp.net-mvc-5 razor-2 dropdownlistfor

我有这个模型:

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属性分配有必须在视图中选择的元素。

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

想法是使用SELECT创建一个视图,该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。

我该如何实现?

谢谢 海梅

1 个答案:

答案 0 :(得分:0)

为了将<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