如何根据 asp.net mvc4 中的模型列表填充 ListBox?

Posted

技术标签:

【中文标题】如何根据 asp.net mvc4 中的模型列表填充 ListBox?【英文标题】:How to populate a ListBox based on a list of a model in asp.net mvc4? 【发布时间】:2013-08-09 20:21:27 【问题描述】:

我有一个强类型视图,其中有一个基于模型联系人的表单。在文本框中,默认值是我传递给控制器​​视图的联系人的值。 所以我有一个类 Contact 如下:

public class Contact
    
        public int IdContact  get; set; 
        public string Nom  get; set; 
        public string Prenom  get; set; 
        public string Email  get; set; 
        public string Fonction  get; set; 
        public List<FonctionContact> ListeFonctions = new List<FonctionContact>();
        public string TelephoneFixe  get; set; 
        public string TelephonePort  get; set; 
        public Contact()  

        public Contact(int idContact, string nom, string prenom, string email, string telephoneFixe, string telephonePort)
        
            this.IdContact = idContact;
            this.Nom = nom;
            this.Prenom = prenom;
            this.Email = email;
            this.TelephoneFixe = telephoneFixe;
            this.TelephonePort = telephonePort;
        

        public Contact(int idContact, string nom, string prenom, List<FonctionContact> listeFonctions, string email, string telephoneFixe, string telephonePort)
        
            this.IdContact = idContact;
            this.Nom = nom;
            this.Prenom = prenom;
            this.ListeFonctions = listeFonctions;
            this.Email = email;
            this.TelephoneFixe = telephoneFixe;
            this.TelephonePort = telephonePort;
        
    

有一个FonctionContact列表。 FonctionContact 的类:

public class FonctionContact

    public int IdFonction;
    public string LibelleFonction;

    public FonctionContact()  

    public FonctionContact(int idFonction, string libelleFonction)
    
        this.IdFonction = idFonction;
        this.LibelleFonction = libelleFonction;
    

所以我想在 listBoxfor 中显示联系人的 ListeFonctions 属性,但它不起作用。我尝试在表单中显示列表:

@using (html.BeginForm()) 
     <label>Nom:</label>
     @Html.TextBoxFor(contact => contact.Nom, new  @Value = @Model.Nom )
     <label>Prénom:</label>
     @Html.TextBoxFor(contact => contact.Prenom, new  @Value = @Model.Prenom )
     ///the next controls for the next properties of class Contact...
     <label>Fonction(s):</label>
     @Html.ListBoxFor(contact => contact.ListeFonctions, new SelectList(Model.ListeFonctions, "IdFonction", "LibelleFonction"));
     

它向我显示一个错误:“Model.FonctionContact 没有属性 IdFonction。所以我被困在这里,我无法找出问题所在。有人有想法吗?

【问题讨论】:

【参考方案1】:

基本上,您需要为 ListBoxFor 提供一个值项列表(整数,您可以使用它来加载一些以前选择和保存的项)。此外,它需要一个 MultiSelectList 作为第二个参数(出于前面解释的原因,因为它不是一个只有一个选定项目的 DropDownList),这可能更适合在模型中组合,如下所示:

型号

public class Contact
        
            public int IdContact  get; set; 
            public string Nom  get; set; 
            public string Prenom  get; set; 
            public string Email  get; set; 
            public string Fonction  get; set; 

            // you could save a selection of items from that list
            private List<int> _selectedFonctionIds;        
            public List<int> SelectedFonctionIds
                get 
                    return _selectedFonctionIds?? new List<int>();
                
                set 
                    _selectedFonctionIds= value;
                
            
            private List<FonctionContact> _listeFonctions;
            public MultiSelectList ListeFonctions
               get 
                  return new MultiSelectList(
                            _listeFonctions,
                            "IdFonction", // dataValueField
                            "LibelleFonction" // dataTextField
                  );
                   
            
            public string TelephoneFixe  get; set; 
            public string TelephonePort  get; set; 
            public Contact()  

            public Contact(int idContact, string nom, string prenom, string email, string telephoneFixe, string telephonePort)
            
                this.IdContact = idContact;
                this.Nom = nom;
                this.Prenom = prenom;
                this.Email = email;
                this.TelephoneFixe = telephoneFixe;
                this.TelephonePort = telephonePort;
            

            public Contact(int idContact, string nom, string prenom, List<int> selectedFonctionIds, List<FonctionContact> listeFonctions, string email, string telephoneFixe, string telephonePort)
            
                this.IdContact = idContact;
                this.Nom = nom;
                this.Prenom = prenom;
                this.SelectedFonctionIds = selectedFonctionIds;
                this._listeFonctions = listeFonctions;
                this.Email = email;
                this.TelephoneFixe = telephoneFixe;
                this.TelephonePort = telephonePort;
            
        

在视图的表单中

@Html.ListBoxFor(contact => contact.SelectedFonctionIds, Model.ListeFonctions)

【讨论】:

我试过了,但它显示了一个数据绑定错误,说 Class FonctionContact 没有像 IdFonction 这样的属性 您是否尝试过将 IdFonction 设为属性(public int IdFonction get; set; 而不仅仅是 public int IdFonction;)? LibelleFonction 也应该这样做。 ... 累了就不要工作了!它有效!,非常感谢@Mark

以上是关于如何根据 asp.net mvc4 中的模型列表填充 ListBox?的主要内容,如果未能解决你的问题,请参考以下文章

ASP.NET MVC4 视图中的模型和 ItemModel 绑定

使用 Json 和 Jquery 的 Asp.net MVC4 中的级联下拉列表不填充

如何在表之间交换行后正确重新排序 ID(jQuery 和 ASP.NET MVC4)

csharp ASP.net MVC4分页列表

如何根据条件禁用列表项 - ASP.NET C#

部分补充翻译转载官方教程Asp.Net MVC4入门指南:添加一个模型