注册 登录
Office中国论坛/Access中国论坛 返回首页

的个人空间 http://www.office-cn.net/?0 [收藏] [复制] [分享] [RSS]

日志

别让MsgBox中断了一些Background的处理作业

已有 103 次阅读2008-2-11 12:52 |个人分类:VBA

别让MsgBox中断了一些Background的处理作业
一旦您呼叫了 MsgBox,您正在执行的一些 Background 的处理作业,例如计数器或时钟...等,都会停下来,直到您回应了 MsgBox 之后,一切才会恢复正常!或许您并不希望如此,这也有可能造成一些不必要的错误! 
要解决这个问题,您必须使用 Windows API 去呼叫 MessageBox Function,它的使用方法、外观和 MsgBox 的结果完全相同,但是它却不会中断一些 Background 的处理作业! 

在以下的范例中,您要在 Form 中加入一个 Label、二个 CommandButton 及一个 Timer,不更改任何属性。 

'在声明区中加入以下声明: 

Private Declare Function MessageBox Lib "user32" Alias "MessageBoxA" (ByVal hwnd As Long, ByVal lpText As String, ByVal lpCaption As String, ByVal wType As Long) As Long 

'加入以下程序码: 

Private Sub Command1_Click() 
    MsgBox "计时器停掉了!", 64, "VB 的讯息框" 
End Sub 

Private Sub Command2_Click() 
    MessageBox Me.hwnd, "注意!计时器还在跑!", "API 的讯息框", 64 
End Sub 

Private Sub Form_Load() 
    Me.TimerInterval = 1000 
    Label1.Caption = "目前的时间是:" & Time 
End Sub 

Private Sub Timer1_Timer() 
    Label1.Caption = "目前的时间是:" & Time 
End Sub 

 

评论 (0 个评论)

facelist doodle 涂鸦板

您需要登录后才可以评论 登录 | 注册

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-5-31 09:01 , Processed in 0.053693 second(s), 14 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

返回顶部