文本框的问题

developer45 2008-04-02 08:44:39
大家好,有这样一个问题:我在文本框的keypress事件中,编写:
如果输入的是字符(例如a等),则弹出对话框,说明无效,重新输入,然后我想清空选中文本框中的内容,该怎样实现呢?
...全文
43 点赞 收藏 7
写回复
7 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
aight 2008-04-03

Private Sub Text1_Change()
If Asc(InStr(1, Text1.Text) = 97) Then
If (MsgBox("输入错误!", vbOKOnly) = vbOK) Then
Text1.SelStart = 0
Text1.SelLength = Text1.Width
Text1.SetFocus
End If
End If
End Sub

因为字母a对应的ASCII值是97,所以在判断的时候用Asc(InStr(1, Text1.Text) = 97)来判断
接着,弹出输入错误,并按了确定之后,就会把输入的a选中,楼主可以试一下.
另外,二楼的keyascii是指的按键对应的ASCII的值.
回复
cbm6666 2008-04-03
Private Sub Text1_KeyPress(KeyAscii As Integer)
If (KeyAscii >= 65 And KeyAscii <= 90) Or (KeyAscii >= 97 And KeyAscii <= 122) Then
KeyAscii = 0 '一般就是不给值
'Text1.Text = "" '把整个Text1清空没道理
MsgBox ("输入无效,请重新输入!")
End If
End Sub


回复
东方之珠 2008-04-02
改成这样:
Private Sub Text1_Change()
If InStr(1, Text1.Text, "a") > 0 Then
MsgBox ("输入无效,请重新输入!")
Text1.Text = ""
End If
End Sub
回复
东方之珠 2008-04-02
哦发现错了:Text1_Change中要取消Text1.Text = "",否则不能输入了。对不起!
回复
东方之珠 2008-04-02
应该这样:

Option Explicit

Private Sub Form_Load()
Text1.Text = ""
End Sub

Private Sub Text1_Change()
If InStr(1, Text1.Text, "a") > 0 Then MsgBox ("输入无效,请重新输入!")
Text1.Text = ""
End Sub
回复
developer45 2008-04-02
太感谢了,你能告诉我那个 KeyAscii = 0 有什么作用吗?
回复
pcwe2002 2008-04-02
Private Sub Text1_KeyPress(KeyAscii As Integer)
If Chr(KeyAscii) = "a" Then
MsgBox "无效"
KeyAscii = 0
Text1.Text = ""
End If
End Sub
回复
相关推荐
发帖
VB基础类
创建于2007-09-28

7492

社区成员

VB 基础类
申请成为版主
帖子事件
创建了帖子
2008-04-02 08:44
社区公告
暂无公告