VB中获取Combox已选项的索引值

PrivateSubCommand1_Click()DimstrAsStringDimi,nAsLongstr=Combo1.TextFori=0ToCombo1.Lis... Private Sub Command1_Click()
Dim str As String
Dim i, n As Long
str = Combo1.Text
For i = 0 To Combo1.ListCount - 1
If Combo1.List(i) = str Then
n = i
Text1.Text = n
End If
Exit For
Next
i = i + 1
End Sub
Private Sub Form_Load()

Combo1.AddItem "你"
Combo1.AddItem "是"
Combo1.AddItem "谁"
End Sub
为什么只有选择第一项时text显示为0,选择其它项text无显示?
展开
 我来答
unsamesky
2013-10-01 · TA获得超过2733个赞
知道小有建树答主
回答量:859
采纳率:100%
帮助的人:418万
展开全部

直接利用组合框Combo1的ListIndex属性即可。没必要弄这么复杂。

你的这些代码:

For i = 0 To Combo1.ListCount - 1
If Combo1.List(i) = str Then
n = i
Text1.Text = n
End If
Exit For
Next

直接替换成下面的代码即可:

Text1.Text = Combo1.ListIndex
veket的小号
2013-10-01 · TA获得超过3371个赞
知道大有可为答主
回答量:3762
采纳率:0%
帮助的人:3931万
展开全部
因为有 exit for 语句提前结束for循环
所以 for循环 在i等于1的时候 执行到 exit for 导致 for循环提前结束

就不会有 i= 1 、i=2...的循环了......... 直接转到next 后的那句 接着执行..........

不信 你 就 先 选 第一项 你 然后点按钮 text1变为0
然后 你再选 第二项或第三项 后 再点 按 text1 保持0 不变......
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
善良的猪头3
2013-10-01 · TA获得超过2930个赞
知道大有可为答主
回答量:2522
采纳率:71%
帮助的人:2758万
展开全部
把Exit For写在if then中间
Private Sub Command1_Click()
Dim str As String
Dim i, n As Long
str = Combo1.Text
For i = 0 To Combo1.ListCount - 1
If Combo1.List(i) = str Then
n = i
Text1.Text = n
Exit For
End If

Next
i = i + 1
End Sub
Private Sub Form_Load()

Combo1.AddItem "你"
Combo1.AddItem "是"
Combo1.AddItem "谁"
End Sub
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
大山说桥架
2013-10-01 · TA获得超过250个赞
知道小有建树答主
回答量:350
采纳率:33%
帮助的人:82.7万
展开全部
exit for
end if
就好了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式