繁体   English   中英

在Winform中按值c#选择组合框项目

[英]select combobox item by value c# in winform

我的组合框具有以下自定义类,并且我试图通过编程方式选择一个值。 我可以使用强制转换按值检索项目,但似乎无法按值选择项目。

string test2 = ((GetAcctNum)_comboBox.SelectedItem).Value; 

//强制转换可以按值检索项目,但是如何按值选择项目?

public class GetAcctNum
{
    public string Value { get; set; }
    public string Text { get; set; }
    public override string ToString()
    {
        return Text;
    }
}

我无法使用以下解决方案,因为我不知道文本。 我只会知道需要在组合框中选择的隐藏值。

_comboBox.SelectedValue = _comboBox.Items.FindByText("text").Value;

下面是我如何将值添加到comboBox

SqlDataReader reader = command.ExecuteReader();
if (reader.HasRows)
 {
     while (reader.Read())
    {
       temp = new GetAcctNum();
       temp.Value = reader["AccountID"].ToString();
       temp.Text = reader["AccountNumber"].ToString();  
        getAcctNum.Add(temp);
        rowsAffected++;
   }
 }
//Omitted for brevity//
foreach (GetAcctNum item in getAcctNum)
{
   _comboBox.Items.Add(item);
}

getAcctNum

当您将帐号列表分配给ComboBox ,请指定向用户显示哪个属性,以及将哪个属性用作选择的基础值。

List<GetAcctNum> accountNumbers = GetAccountNumbersFromWherever();

_comboBox.DataSource = accountNumbers;
_comboBox.DisplayMember = "Text";
_comboBox.ValueMember = "Value";

然后,您可以通过指定帐户列表中的值之一来设置SelectedValue

_comboBox.SelectedValue = "SomeValueFromYourListOfAccounts";

使用此类和方法按值选择项目。

    public class ComboboxItem
    {
        public string Text { get; set; }
        public object Value { get; set; }

        public ComboboxItem(string text, string value)
        {
            Text = text;
            Value = value;
        }
        public override string ToString()
        {
            return Text;
        }
    }


    private  void SelectCmbItemByValue( ComboBox cbo, string value)
    {
        for (int i = 0; i < cbo.Items.Count; i++)
        {

            ComboboxItem ci = (ComboboxItem)cbo.Items[i];
            string _value = ci.Value.ToString();
            if (ci != null && _value == value)
            {
                cbo.SelectedIndex = i;
                break;
            }
        }

    }

比你,这对我帮助很大

那工作

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM