Кроме прямого добавления элементов в коллекцию Items
компонентов ListBox и ComboBox мы также можем использовать механизм привязки
данных.
Привязка данных в ListBox и ComboBox реализуется с помощью следующих свойств:
DataSource: источник данных - какой-нибудь массив или коллекция объектов
DisplayMember: свойство объекта, которое будет использоваться для отображения в ListBox / ComboBox
ValueMember: свойство объекта, которое будет использоваться в качестве его значения
Рассмотрим пример.
public partial class Form1 : Form { public Form1() { InitializeComponent(); List<Phone> phones = new List<Phone> { new Phone { Id=11, Name="Samsung Galaxy Ace 2", Year=2012}, new Phone { Id=12, Name="Samsung Galaxy S4", Year=2013}, new Phone { Id=13, Name="iPhone 6", Year=2014}, new Phone { Id=14, Name="Microsoft Lumia 435", Year=2015}, new Phone { Id=15, Name="Xiaomi Mi 5", Year=2015} }; listBox1.DataSource = phones; listBox1.DisplayMember = "Name"; listBox1.ValueMember = "Id"; listBox1.SelectedIndexChanged += listBox1_SelectedIndexChanged; } void listBox1_SelectedIndexChanged(object sender, EventArgs e) { // получаем id выделенного объекта int id = (int)listBox1.SelectedValue; // получаем весь выделенный объект Phone phone = (Phone)listBox1.SelectedItem; MessageBox.Show(id.ToString() + ". " + phone.Name); } } class Phone { public int Id { get; set; } public string Name { get; set; } public int Year { get; set; } }
Итак, на форме у нас есть список ListBox с именем listBox1. В коде имеется класс Phone с тремя свойствами, объекты которого мы хотим выводить в список. В отличие от предыдущих тем эта задача сложнее, так как раньше мы выводили обычные строки, тут же у нас сложные объекты.
Для вывода используем механизм привязки. Сначала устанавливаем список телефонов в качестве источника данных:
listBox1.DataSource = phones;
Затем устанавливаем в качестве отображаемого свойства свойство Name класса Phone, а в качестве свойства значения - свойство Id:
listBox1.DisplayMember = "Name"; listBox1.ValueMember = "Id";
Значение отображаемого свойства мы затем увидим в списке. Оно будет представлять каждый отдельный объект Phone.
С помощью же свойства значения, которым является свойство Id, мы можем упростить работу с источником данных. В данном случае оно не играет большой роли. Но если бы мы использовали в качестве источника данных некоторый набор объектов из базы данных, то с помощью id нам было проще удалять, обновлять и взаимодействовать с базой данных.
И теперь если мы выделим какой-то объект, то свойство SelectedItem элементы ListBox будет содержать объект Phone, у которого мы можем получить значения свойств:
Phone phone = (Phone)listBox1.SelectedItem; string name = phone.Name;
А выделенное значение, то есть значение свойства Id выделенного телефона, будет находиться в свойстве SelectedValue.
И если мы запустим приложение, то увидим все отображаемые телефоны:
Все то же самое характерно и для элемента ComboBox. Пусть кроме ListBoxa на форме есть ComboBox:
public partial class Form1 : Form { public Form1() { InitializeComponent(); List<Phone> phones = new List<Phone> { new Phone { Id=11, Name="Samsung Galaxy Ace 2", Year=2012}, new Phone { Id=12, Name="Samsung Galaxy S4", Year=2013}, new Phone { Id=13, Name="iPhone 6", Year=2014}, new Phone { Id=14, Name="Microsoft Lumia 435", Year=2015}, new Phone { Id=15, Name="Xiaomi Mi 5", Year=2015} }; comboBox1.DataSource = phones; comboBox1.DisplayMember = "Name"; comboBox1.ValueMember = "Id"; comboBox1.SelectedIndexChanged += comboBox1_SelectedIndexChanged; listBox1.DisplayMember = "Name"; listBox1.ValueMember = "Id"; } void comboBox1_SelectedIndexChanged(object sender, EventArgs e) { Phone phone = (Phone)comboBox1.SelectedItem; listBox1.Items.Add(phone); } } class Phone { public int Id { get; set; } public string Name { get; set; } public int Year { get; set; } }
Здесь также для комбобокса устанавливается привязка, а также отображаемое свойство и свойство значения. Кроме того, здесь обрабатывается событие выбора элемента в комбобоксе так, чтобы выбранный элемент попадал в ListBox.
В отличие от ListBoxa ComboBox имеет три свойства для обработки выделенного объекта:
SelectedItem
: выбранный элемент
SelectedValue
: значение свойства значения, в данном случае свойство Id
SelectedText
: значение свойства отображение, в данном случае свойство Name класса Phone