Несколько ValueMembers из одного ComboBox C#

Я хотел бы назначить более одного поля для значения элемента в поле со списком. Как видно из кода, текущей строкой, присваиваемой элементу value, является "title", а в событии cboCustomers_SelectionChangeCommited вы можете видеть, что текстовому полю было присвоено выбранное значение.

Я надеюсь добиться того, чтобы еще 2 поля были назначены элементу value ("имя", "фамилия") и еще два текстовых поля были назначены с этими значениями.

Я надеюсь, что я был ясен. Если нет, пожалуйста, укажите, и я попытаюсь объяснить это.

 private void Form3_Load(object sender, EventArgs e)
                    {
                        try
                        {
                            dbConn = new OleDbConnection(conString);
                            sql = @"SELECT customer.title, firstname, lastname, product.name, account.balance
                                  FROM (account INNER JOIN customer ON account.custid = customer.custid) INNER JOIN product ON account.prodid = product.prodid;";

                            daItems = new OleDbDataAdapter(sql, dbConn);
                            daItems.Fill(dtAccBal);


                            cboCustomers.DataSource = (dtAccBal);
                            cboCustomers.DisplayMember = "firstname";
                            cboCustomers.ValueMember = "title";
                            cboCustomers.SelectedIndex = -1;

                        }
                        catch (Exception ex)
                        {
                            MessageBox.Show(ex.Message, "Error!");
                        }
                    }


                    private void cboCustomers_SelectionChangeCommitted(object sender, EventArgs e)
                    {
                        if (cboCustomers.SelectedIndex > -1)
                        {
                            try
                            {
                                txtTitle.Text = cboCustomers.SelectedValue.ToString();



                            }
                            catch (Exception ex)
                            {
                                MessageBox.Show(ex.Message, "Error!");
                            }
                        }
                    }
                }

1 ответ

Решение

Вы можете использовать объект, который реализует INotifyPropertyChanged интерфейс и добавить DataBindings к вашим TextBoxes.

Пример:

Класс Person, который реализует INotifyPropertyChanged

public class Person : INotifyPropertyChanged
{
    private string _firstName;
    public string FirstName
    {
        get { return _firstName; }
        set
        {
            if (value == _firstName) return;
            _firstName = value;
            OnPropertyChanged();
        }
    }

    private string _lastName;
    public string LastName
    {
        get { return _lastName; }
        set
        {
            if (value == _lastName) return;
            _lastName = value;
            OnPropertyChanged();
        }
    }

    public override string ToString() => $"{FirstName} {LastName}";

    public event PropertyChangedEventHandler PropertyChanged;
    protected virtual void OnPropertyChanged([CallerMemberName] string propertyName = null)
    {
        PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
    }
}

Добавить в форму ComboBox "comboBoxPeople" и два TextBoxes "textBoxFirstName", "textBoxLastName".

Изменить конструктор формы:

public Form1()
{
    InitializeComponent();

    var people = new BindingList<Person> {
        new Person() { FirstName = "Peter", LastName = "Pan" },
        new Person() { FirstName = "Tinker", LastName = "Bell" },
        new Person() { FirstName = "James", LastName = "Hook" },
        new Person() { FirstName = "Wendy", LastName = "Darling" },
    };

    var bindingSource = new BindingSource() { DataSource = people };

    comboBoxPeople.DataSource = bindingSource;
    textBoxFirstName.DataBindings.Add(nameof(TextBox.Text), bindingSource, nameof(Person.FirstName), false, DataSourceUpdateMode.OnPropertyChanged);
    textBoxLastName.DataBindings.Add(nameof(TextBox.Text), bindingSource, nameof(Person.LastName), false, DataSourceUpdateMode.OnPropertyChanged);
}

Теперь у вас есть поле со списком, заполненным людьми. После выбора другого человека текстовые поля будут заполнены соответствующими данными автоматически.

Другие вопросы по тегам