1. 文本框始终得到焦点
Private Sub Text1_LostFocus()
Text1.SetFocus
End Sub
2. Undo的实现
找了一篇文章给你,希望对你有所帮助。
-------------------------------------
用Visual Basic实现undo功能
一、设计思路
一般的字处理软件,如WPS Office、Word都有撤销功能,极大地方便了用户,可是这项功能用VB该如何实现呢?这就要用到SendMessage函数,该函数的功能就是向指定的窗口发送一条消息,他有4个参数,含义如下:
.hWnd:用来指定要接受消息的窗口的句柄;
.wMsg:用来指定要发送的消息的编号;
.wParam:用来指定消息的第一参数;
.1Param:用来消息的第二参数。
二、实战
新建一个EXE窗体,上面放置一个textbox、两个 commndbotton控件,名称分别为text1、command1、command2,caption分别为text1、撤销、退出,其他配置取默认值。
打开API阅览器,将函数SendMessage复制到窗体代码中。任何源代码如下:
Option Explicit
Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, lParam As Any) As Long
Private Const EM_CANUNDO = &HC6
Private Const EM_UNDO = &HC7
Private Sub Command1_Click()
Dim i As Integer
i = SendMessage(Text1.hwnd, EM_UNDO, 0, 0)
End Sub
Private Sub Command2_Click()
End
End Sub
在这个程式中,我们向文本框发送了一个EM_UNDO消息,该消息的功能是取消文本框的最后一个编辑操作。对于该消息,wParam和1Param均无用,故都设为0。
按F5看看效果吧,是不是有一种成就感。以上代码在windowsXP家庭版和VB6中文企业版下运行通过。
-------------------------------------
1、
Private Sub Form_Load()
Text1.SetFocus
End Sub
Private Sub Text1_LostFocus()
Text1.SetFocus
End Sub
2、
Private Sub Command1_Click()
Text1 = Text1 & vbCrLf & neirong
End Sub
Private Sub Command1_Click()
Text1 = Text1 & vbCrLf & neirong
End Sub
Private Sub Command2_Click()
Dim r
r = Split(Text1, vbCrLf)
For i = 1 To UBound(r) - 1
Text1 = Text1 & vbCrLf & r(i)
Next i
End Sub