web-dev-qa-db-ja.com

プログラムでC#ドロップダウンリストを検索する方法

テキストボックスに入力された特定の値をさまざまなドロップダウンリストで検索する一連の「if」ステートメントをコーディングする方法を理解するのに苦労しています。各ドロップダウンリストで特定の値を見つけるコードを書くことができました。ただし、これが発生する前に、「ドロップダウンリストに特定の値が含まれていない場合は、次のifステートメントに進むなど」という「if」ステートメントを追加する必要があります。以下は私がこれまでに持っているものの例です:

if (dropdownlist1.SelectedValue == textbox1)
{
  dropdownlist1.SelectedIndex = dropdownlist1.items.indexof(dorpdownlist1.items.findbyvalue(textbox1.text) ...

if (dropdownlist2.SelectedValue == textbox1)
{
  dropdownlist2.SelectedIndex = dropdownlist2.items.indexof(dorpdownlist2.items.findbyvalue(textbox1.text) ...

etc...

これは、textbox1のエントリに基づいて、各ドロップダウンリストの最初の値またはインデックスを読み取るかスキ​​ャンします。残念ながら、最初の値またはインデックスのみを識別します。ドロップダウンリスト全体をスキャンして、各「if」ステートメントごとのすべての値をスキャンし、一致するtextbox1値を見つける方法を理解する必要があります。誰か提案がありますか?

ありがとうございました、

DFM

10
DFM
foreach (ListItem li in dropdownlist1.Items)
{
    if (li.Value == textBox1.text)
    {
       // The value of the option matches the TextBox. Process stuff here.
    }
}

これは、値がドロップダウンリストにあるかどうかを確認する方法についての私の提案です。

22
JB King

DropDownListListControl から Items コレクションを継承します。 Itemsは配列であるため、次の構文を使用できます。

dropdownlist1.Items.Contains(textbox1.Text)をブール値として。

7
Drew McGhie

あなたは単にこのようにすることができます。

if (ddl.Items.FindByValue("value") != null) {
   ddl.SelectedValue = "value";
};
3
Iyyappan

ドロップダウンボックスのリストを作成し、linqを使用して選択します。

List<DropDownList> list = new List<DropDownList>();
list.Item.Add(dropdown1);
list.Item.Add(dropdown2); 
.... (etc)

var selected = from item in list.Cast<DropDownList>()
               where item.value == textBox1.text
               select item;
2
Eldila

提示されたソリューションは、ロードされたコンボボックスで正確な値を検索する場合に機能します。

このソリューションは、部分的な値も検索します。検索ボタンとドロップダウンボックスのテキスト部分を検索条件として使用します

Private Sub btnSearch_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnSearch.Click

    ' query the dropdown object
    ''''''''''''
    ' part 9457 is a "contains" sample
    ' part 111 is a "startswith" sample

    Dim query As IEnumerable(Of [Object]) = _
    From item In cboParts.Items _
    Where (item.ToString().ToUpper().StartsWith(cboParts.Text.ToUpper())) _
    Select (item)

    ' show seached item as selected item
    cboParts.SelectedItem = query.FirstOrDefault()

    ' "startswith" fails, so look for "contains" 
    If String.IsNullOrEmpty(cboParts.SelectedItem) Then

        Dim query1 As IEnumerable(Of [Object]) = _
        From item In cboParts.Items _
        Where (item.ToString().ToUpper().Contains(cboParts.Text.ToUpper())) _
        Select (item)

        ' show seached item as selected item
        cboParts.SelectedItem = query1.FirstOrDefault()

        If String.IsNullOrEmpty(cboParts.SelectedItem) Then
            MsgBox("Part is not in dropdown list")
        End If

    End If
2
Mike

ドロップダウンリストでテキストでアイテムを検索しようとしていました。私は以下のコードを使用しました、それは機能します:)

ListItem _lstitemTemp = new ListItem("Text To Find In Dropdownlist");
if(_DropDownList.Items.Contains(_lstitemTemp))
{
    dosomething();
}
1
ThrasHate

読みやすくするために1行のコード分割。

this.DropDownList1.SelectedItem = this.DropDownList1.Items
     .SingleOrDefault(ddli => ddli.value == this.textbox1.value);
0
tom.dietrich

LINQを使用したくない場合:

        List<ComboBox> dropDowns = new List<ComboBox>();
        dropDowns.Add(comboBox1);
        dropDowns.Add(comboBox2);

        bool found = false;
        ComboBox foundInCombo = null;
        int foundIndex = -1;

        for (int i = 0; i < dropDowns.Count && found == false; i++)
        {
            for (int j = 0; j < dropDowns[i].Items.Count && found == false; j++)
            {
                if (item == textBox1.Text)
                {
                    found = true;
                    foundInCombo = dropDowns[i];
                    foundIndex = j;
                }
            }
        }
0
Martin Brown