在VB中,限制TextBox只能输入数字,包括粘贴
有时候,我们在设计程序时需要限定文本框只能输入数字,鉴于网上现存的代码都不完善,比如不能输入小数、负数;用KeyPress会把退格、DEL、CTRL+V等一并过滤;用Change事件则在输入“-”时就即时判定为非数字;而采用Val函数则“1d1e2”这样的非法字符串也会误认为是数字的;用API则太繁琐。
有鉴于此,我特意写了一段代码用来限定在VB的TextBox控件中只能输入实数,可以检测直接粘贴到TextBox中的内容是否为实数,且不改变光标的位置,而且是直接写成模块的,可以供任意多个TextBox调用。
首先,我们最好是添加一个模块,那么无论你有多少个TextBox控件需要实现只能输入数字,都可以直接调用即可。
打开Modoule1模块,先定义3个全局变量,用来保存TextBox的现态,代码如下:
'LastText变量用于记录TextBox的上次正确输入
'LastLen变量用于保存TextBox的上次正确输入时的字符串长度,以便恢复光标的上次位置
'NotText变量用来防止在进行撤销行为时进行2次检测而增加CPU负担
Public LastText As String, LastLen As Integer, NotText As Boolean
由于我的方法是检测到输入非数字,即撤销到上一步状态,所以我们要对需要限定的TextBox赋一个正确的初始值,还是写成模块,这样可以方便所有的TextBox调用,代码如下:
Function Initialize(MyText As TextBox)
Dim a$
a = MyText & "1"
If Not IsNumeric(a) Then MyText = "0" ‘保证TextBox的初始值是数字
LastText = MyText
LastLen = Len(MyText)
NotText = False
End Function
然后是核心代码,就是对输入或粘贴到文本框的内容是否为数字进行检测,通用同样写在Modoule1模块中,代码如下:
Function OnlyNumbers(MyText As TextBox)
If NotText Then NotText = False: Exit Function
Dim a$, b$, c%, d%
a = MyText.Text
b = a
c = Len(MyText.Text)
'保存光标的位置,网上很多限制只能输入数字的代码要么屏蔽了退格、小数点等键,要么把光标位置给变了
d = MyText.SelStart
'字符D是十进制数结尾标志,字符E是科学计数法形式,下边这2行是屏蔽这2个字母的,如果需要使用科学计数法,可以自己灵活修改
a = Replace(a, "E", "", 1, -1, 1)
a = Replace(a, "D", "", 1, -1, 1)
'屏蔽字母D和E的同时会使光标位置的判断出错
If a <> b Then d = d - 1
'这样给b赋值是考虑负数和小数的情况,如果是正整数去掉此行和上一行即可
b = a & "1"
'是否允许TextBox的内容为空这里,可以自行设置,我这里是允许为空的
If a = "" Then Exit Function
'之所以采用出错即撤销到上次正确的方法,是因为按键检测的方法是无法对直接粘贴的数据进行检测的
If IsNumeric(b) Then
LastText = a
LastLen = Len(a)
Else
NotText = True
a = LastText
d = d + LastLen - c
End If
'恢复光标所在的位置
MyText.Text = a
MyText.SelStart = d
End Function
我们把核心代码全部写成了模块,所以,大家看不懂也没关系,把我写的模块直接复制、粘贴即可。在窗体中只需要调用我写的2个模块即可,比如想限定Text1只能输入数字,可以加入下列代码:
Private Sub Text1_Change()
OnlyNumbers Me.Text1
End Sub
Private Sub Text1_GotFocus()
Initialize Me.Text1
End Sub
同样,如果有Text2、Text3等多个TextBox需要限定,也只需调用我写的模块即可。而且即使是Form2中的Text2也可以调用的,如下:
Private Sub Text2_Change()
OnlyNumbers Form2.Text2
End Sub
Private Sub Text2_GotFocus()
Initialize Form2.Text2
End Sub
然后,我随便画了2个TextBox,可以看到对Text1的输入限定,并不影响对Text2的输入限定的:
版权声明:本站【趣百科】文章素材来源于网络或者用户投稿,未经许可不得用于商用,如转载保留本文链接:https://www.qubaik.com/article/72790.html