Porady: określanie elementów jako zaznaczone w formancie CheckedListBox formularzy systemu Windows
Podczas prezentowania danych w kontrolce Formularze systemu CheckedListBox Windows można wykonać iterację po kolekcji przechowywanej CheckedItems we właściwości lub przejść przez listę przy użyciu GetItemChecked metody w celu określenia, które elementy są sprawdzane. Metoda GetItemChecked przyjmuje numer indeksu elementu jako argument i zwraca true
wartość lub false
. W przeciwieństwie do tego, czego można się spodziewać, właściwości i SelectedIndices nie określają, które elementy są sprawdzane; określają one, SelectedItems które elementy są wyróżnione.
Aby określić zaznaczone elementy w kontrolce CheckedListBox
Iterowanie po CheckedItems kolekcji, począwszy od wartości 0, ponieważ kolekcja jest oparta na wartości zerowej. Należy pamiętać, że ta metoda da numer elementu na liście zaznaczonych elementów, a nie ogólną listę. Jeśli więc pierwszy element na liście nie jest zaznaczony, a drugi element zostanie sprawdzony, poniższy kod wyświetli tekst taki jak "Sprawdzony element 1 = MyListItem2".
' Determine if there are any items checked. If CheckedListBox1.CheckedItems.Count <> 0 Then ' If so, loop through all checked items and print results. Dim x As Integer Dim s As String = "" For x = 0 To CheckedListBox1.CheckedItems.Count - 1 s = s & "Checked Item " & (x + 1).ToString & " = " & CheckedListBox1.CheckedItems(x).ToString & ControlChars.CrLf Next x MessageBox.Show(s) End If
// Determine if there are any items checked. if(checkedListBox1.CheckedItems.Count != 0) { // If so, loop through all checked items and print results. string s = ""; for(int x = 0; x < checkedListBox1.CheckedItems.Count ; x++) { s = s + "Checked Item " + (x+1).ToString() + " = " + checkedListBox1.CheckedItems[x].ToString() + "\n"; } MessageBox.Show(s); }
// Determine if there are any items checked. if(checkedListBox1->CheckedItems->Count != 0) { // If so, loop through all checked items and print results. String ^ s = ""; for(int x = 0; x < checkedListBox1->CheckedItems->Count; x++) { s = String::Concat(s, "Checked Item ", (x+1).ToString(), " = ", checkedListBox1->CheckedItems[x]->ToString(), "\n"); } MessageBox::Show(s); }
- Lub-
Przejdź do kolekcji Items , zaczynając od wartości 0, ponieważ kolekcja jest oparta na zera, i wywołaj metodę GetItemChecked dla każdego elementu. Należy pamiętać, że ta metoda da numer elementu na ogólnej liście, więc jeśli pierwszy element na liście nie jest zaznaczony, a drugi element jest zaznaczony, zostanie wyświetlony element podobny do "Item 2 = MyListItem2".
Dim i As Integer Dim s As String s = "Checked Items:" & ControlChars.CrLf For i = 0 To (CheckedListBox1.Items.Count - 1) If CheckedListBox1.GetItemChecked(i) = True Then s = s & "Item " & (i + 1).ToString & " = " & CheckedListBox1.Items(i).ToString & ControlChars.CrLf End If Next MessageBox.Show(s)
int i; string s; s = "Checked items:\n" ; for (i = 0; i <= (checkedListBox1.Items.Count-1); i++) { if (checkedListBox1.GetItemChecked(i)) { s = s + "Item " + (i+1).ToString() + " = " + checkedListBox1.Items[i].ToString() + "\n"; } } MessageBox.Show (s);
int i; String ^ s; s = "Checked items:\n" ; for (i = 0; i <= (checkedListBox1->Items->Count-1); i++) { if (checkedListBox1->GetItemChecked(i)) { s = String::Concat(s, "Item ", (i+1).ToString(), " = ", checkedListBox1->Item[i]->ToString(), "\n"); } } MessageBox::Show(s);
Zobacz też
.NET Desktop feedback