怎样为VB窗体中的所有文本框限制只输入数字?

我知道单一个文本框是这样写PrivateSubtext1_KeyPress(KeyAsciiAsInteger)IfKeyAscii=46AndNotCBool(InSt... 我知道单一个文本框是这样写
Private Sub text1_KeyPress(KeyAscii As Integer)
If KeyAscii = 46 And Not CBool(InStr(text1, ".")) Then Exit Sub
If KeyAscii = 8 Then Exit Sub
If KeyAscii < 48 Or KeyAscii > 57 Then KeyAscii = 0
End Sub
展开
 我来答
网海1书生
科技发烧友

推荐于2016-04-21 · 擅长软件设计、WEB应用开发、小程序
网海1书生
采纳数:12310 获赞数:26225

向TA提问 私信TA
展开全部

除非你的所有文本框属于同一个控件数组,否则的话就要给每个文本框都写个同样的事件代码了(当然也可以做个自定义过程稍微简化一下)

如果是控件数组,那么只需一个事件过程即可:

Private Sub Text1_KeyPress(Index As Integer, KeyAscii As Integer)
If KeyAscii = 46 And InStr(Text1(Index), ".")) = 0 Then Exit Sub
If KeyAscii = 8 Then Exit Sub
If KeyAscii < 48 Or KeyAscii > 57 Then KeyAscii = 0
End Sub

如果不是控件数组,那么就只能这样:

Function chkkey(t As String, k As Integer) As Integer
chkkey = k
If k = 46 And InStr(t, ".")) = 0 Then Exit Function
If k = 8 Then Exit Function
If k < 48 Or k > 57 Then chkkey = 0
End Function

Private Sub Text1_KeyPress(KeyAscii As Integer)
    KeyAscii = chkkey(Text1.Text, KeyAscii)
End Sub

Private Sub Text2_KeyPress(KeyAscii As Integer)
    KeyAscii = chkkey(Text2.Text, KeyAscii)
End Sub

Private Sub Text3_KeyPress(KeyAscii As Integer)
    KeyAscii = chkkey(Text3.Text, KeyAscii)
End Sub

'...依此类推
會美男子
2021-02-18
知道答主
回答量:9
采纳率:0%
帮助的人:6003
展开全部
Private Sub Text1_LostFocus() ‘鼠标移开文本框1
If Not IsNumeric(Text1) Then ’如果文本框1里的内容非数字
Text1.Text = "" ‘文本框1清空
End If
End Sub

依次类推
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
ylmyzjz
2014-02-16 · TA获得超过135个赞
知道答主
回答量:183
采纳率:0%
帮助的人:131万
展开全部
把中间的代码整合成一个过程,然后逐个引用。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式