Копирование списка VB6
Используя Visual Basic 6.0, я пытаюсь заполнить одно окно списка элементами другого списка.
Может кто-нибудь объяснить, почему следующий подпрограмма не работает должным образом, получая несоответствие типов при передаче двух списков в качестве параметров.
Public Sub copyListboxes(Byref lstFrom as Listbox, Byref lstTo as Listbox)
Dim i as integer
For i = 0 to lstFrom.Listcount -1
lstTo.Additem lstFrom.List(i)
Next i
End Sub
'Call copyListboxes(Listbox1,Listbox2) 'Type Mismatch ... ?
Заранее спасибо.
1 ответ
Решение
Я смог воспроизвести вашу ошибку, используя Comboxes вместо Listboxes:
'1 form with:
' 1 command button: name=Command1
' 2 combobox controls: name=Listbox1 name=Listbox2
Option Explicit
Private Sub Command1_Click()
Call copyListboxes(Listbox1, Listbox2) 'Type Mismatch!
End Sub
Public Sub copyListboxes(ByRef lstFrom As ListBox, ByRef lstTo As ListBox)
Dim i As Integer
For i = 0 To lstFrom.ListCount - 1
lstTo.AddItem lstFrom.List(i)
Next i
End Sub
Private Sub Form_Load()
Dim intIndex As Integer
For intIndex = 1 To 10
Listbox1.AddItem CStr(intIndex)
Next intIndex
End Sub
Чтобы решить эту проблему, вы можете использовать элементы управления Listbox или изменить свой саб для работы с элементами управления Combobox:
Public Sub copyListboxes(ByRef lstFrom As ComboBox, ByRef lstTo As ComboBox)
Dim i As Integer
For i = 0 To lstFrom.ListCount - 1
lstTo.AddItem lstFrom.List(i)
Next i
End Sub