テキストボックスに入力された特定の値をさまざまなドロップダウンリストで検索する一連の「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
foreach (ListItem li in dropdownlist1.Items)
{
if (li.Value == textBox1.text)
{
// The value of the option matches the TextBox. Process stuff here.
}
}
これは、値がドロップダウンリストにあるかどうかを確認する方法についての私の提案です。
DropDownList は ListControl から Items コレクションを継承します。 Itemsは配列であるため、次の構文を使用できます。
dropdownlist1.Items.Contains(textbox1.Text)をブール値として。
あなたは単にこのようにすることができます。
if (ddl.Items.FindByValue("value") != null) {
ddl.SelectedValue = "value";
};
ドロップダウンボックスのリストを作成し、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;
提示されたソリューションは、ロードされたコンボボックスで正確な値を検索する場合に機能します。
このソリューションは、部分的な値も検索します。検索ボタンとドロップダウンボックスのテキスト部分を検索条件として使用します
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
ドロップダウンリストでテキストでアイテムを検索しようとしていました。私は以下のコードを使用しました、それは機能します:)
ListItem _lstitemTemp = new ListItem("Text To Find In Dropdownlist");
if(_DropDownList.Items.Contains(_lstitemTemp))
{
dosomething();
}
読みやすくするために1行のコード分割。
this.DropDownList1.SelectedItem = this.DropDownList1.Items
.SingleOrDefault(ddli => ddli.value == this.textbox1.value);
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;
}
}
}