我在表单上有一个列表框,它适用于我想要做的事情.
我想编辑表单上的项目,这意味着填充列表框,然后选择相关项目.
我的列表框包含项目大小列表,我想选择属于正在编辑的项目的大小.
可以有人给我一些指示.
我试过me.lstItemSizes.SetSelected(i,true),但这仅适用于单个项目.
任何帮助将不胜感激.
我的代码:
- Private Sub SelectItemSizes(ByVal itemID As Integer)
- Dim itemSizes As IList(Of ItemSize) = _sizeLogic.GetItemSizes(itemID)
- Me.lstItemSizes.SelectionMode = SelectionMode.MultiExtended
- If (itemSizes.Count > 0) Then
- For i As Integer = 0 To Me.lstItemSizes.Items.Count - 1
- For x As Integer = 0 To itemSizes.Count - 1
- If (CType(Me.lstItemSizes.Items(i),PosSize).SizeID = itemSizes(x).SizeID) Then
- Me.lstItemSizes.SetSelected(i,True)
- Else
- Me.lstItemSizes.SetSelected(i,False)
- End If
- Next
- Next
- End If
- End Sub
你是否将selectionmode设置为multi?
您需要指定它以允许多个选择.
然后你可以这样做:
这是一个屏幕截图:
在列表框上设置属性后,根据要选择的值调用setselected.
- me.lstItemSizes.SetSelected(3,true)
- me.lstItemSizes.SetSelected(4,true)
- me.lstItemSizes.SetSelected(9,true)
在这里你可以添加20个数字,只选择偶数.
第3次编辑
看看你循环的方式,让我们假设我创建了一个整数列表,我的vb.net生锈了我主要用C#开发.但假设你这样做:
- Dim l As New List(Of Integer)
- l.Add(2)
- l.Add(6)
- l.Add(20)
您的列表中只有三个项目,因此首先根据列表中的项目进行循环,然后在列表框中的项目中进行循环,反之亦然.看这个:
- Dim i As Integer
- Dim l As New List(Of Integer)
- l.Add(2)
- l.Add(6)
- l.Add(20)
- 'load the list with 20 numbers
- For i = 0 To 20
- Me.ListBox1.Items.Add(i)
- Next
- Dim lCount As Integer = 0
- For lCount = 0 To l.Count - 1
- For i = 0 To 20
- If i = l.Item(lCount) Then
- Me.ListBox1.SetSelected(i,True)
- Exit For
- End If
- Next
- Next
在代码中,我的列表只包含3个项目:2个,6个和20个.
我将这些项添加到l,它只是一个列表对象.
所以现在我必须循环使用这3个数字并与我的列表框进行比较.你可以在列表框上循环,然后考虑列表对象.
请注意,在我的for循环中,一旦找到列表中的项目,我就不再需要循环,所以我退出了.这确保我不会过度所需的循环量.找到项目后退出并返回列表对象计数.
运行我的代码之后是结果