我正在使用Visual Basic 2010,我想知道的是我如何在单个ComboBox上创建不同的列表... 几乎我有2个ComboBox ...第一个带有项目列表里面..我想根据第一个ComboBox的选择创建第二个包含不同类型列表的ComboBox ..
Ex:第一个Combobox与所有大陆和第二个ComboBox与所有国家,我希望第二个ComboBox的国家列表根据从第一个ComboBox列表中选择的国家进行更改...
答案 0 :(得分:3)
以下是两个代表 country 和 continent 的类:
'Coded by Amen Ayach's DataClassBuilder @25/02/2012
Public Class CountryCls
Private _CountryID As Integer
Public Property CountryID() As Integer
Get
Return _CountryID
End Get
Set(ByVal value As Integer)
_CountryID = value
End Set
End Property
Private _CountryName As String
Public Property CountryName() As String
Get
Return _CountryName
End Get
Set(ByVal value As String)
_CountryName = value
End Set
End Property
Private _ContinentID As Integer
Public Property ContinentID() As Integer
Get
Return _ContinentID
End Get
Set(ByVal value As Integer)
_ContinentID = value
End Set
End Property
End Class
'Coded by Amen Ayach's DataClassBuilder @25/02/2012
Public Class ContinentCls
Private _ContinentID As Integer
Public Property ContinentID() As Integer
Get
Return _ContinentID
End Get
Set(ByVal value As Integer)
_ContinentID = value
End Set
End Property
Private _ContinentName As String
Public Property ContinentName() As String
Get
Return _ContinentName
End Get
Set(ByVal value As String)
_ContinentName = value
End Set
End Property
End Class
现在将两个ComboBoxs
添加到名为 cmbContinent 和 cmbCountry 的表单中,然后将以下代码添加到表单中:
Dim ContinentList As New List(Of ContinentCls)
Dim CountryList As New List(Of CountryCls)
Private Sub Form2_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
'Initialize some fake data
For i = 1 To 3
ContinentList.Add(New ContinentCls With {.ContinentID = i, .ContinentName = "Continent" + CStr(i)})
For j = 1 To 5
CountryList.Add(New CountryCls With {.ContinentID = i, .CountryID = j, .CountryName = "Cont" + CStr(i) + " - Country" + CStr(j)})
Next
Next
'Filling out ContinentCombo
With cmbContinent
.ValueMember = "ContinentID"
.DisplayMember = "ContinentName"
.DataSource = ContinentList
End With
End Sub
Private Sub cmbContinent_SelectedValueChanged(ByVal sender As Object, ByVal e As System.EventArgs) Handles cmbContinent.SelectedValueChanged
Try
'Filling out CountryCombo according to seleced ContinentCombo
With cmbCountry
.ValueMember = "CountryID"
.DisplayMember = "CountryName"
.DataSource = CountryList.Where(Function(f) f.ContinentID = cmbContinent.SelectedValue).ToList
End With
Catch ex As Exception
MsgBox(ex.Message)
End Try
End Sub