Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/video/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Vba 防止MsgBox与现有警报重叠_Vba_Outlook - Fatal编程技术网

Vba 防止MsgBox与现有警报重叠

Vba 防止MsgBox与现有警报重叠,vba,outlook,Vba,Outlook,我正在使用SetTimer()检查特定邮箱中是否存在超过1小时的电子邮件,并显示一个MsgBox()警报,通知我此类邮件。问题是如果我让Outlook通宵打开,我可能会返回20-30个重叠的MsgBox()alerts 如何约束程序仅显示一个警报,并且在当前显示的MsgBox()被取消之前不继续显示更多警报?如果有打开的警报,为什么不设置一个标志?下次计时器过期时,您将检查标志,但不执行任何操作。一旦用户关闭警报,您将重置标志 编辑: 一个轻微的优化是在显示第一个警报之前停止计时器。用户确认警报

我正在使用
SetTimer()
检查特定邮箱中是否存在超过1小时的电子邮件,并显示一个
MsgBox()
警报,通知我此类邮件。问题是如果我让Outlook通宵打开,我可能会返回20-30个重叠的
MsgBox()
alerts


如何约束程序仅显示一个警报,并且在当前显示的
MsgBox()
被取消之前不继续显示更多警报?

如果有打开的警报,为什么不设置一个标志?下次计时器过期时,您将检查标志,但不执行任何操作。一旦用户关闭警报,您将重置标志

编辑: 一个轻微的优化是在显示第一个警报之前停止计时器。用户确认警报后,您将重新启动计时器。这样你甚至可以节省一些CPU

这样可以防止多个警报。
我错过了什么吗?

没有,没有错过任何东西。我只是觉得VBA足够聪明,不会无休止地重叠消息框。我将采用你提出的一种解决方案。谢谢。不久前,当我用另一种语言遇到这个问题时,我也有同样的想法:D