vb.net – VBA中的AndAlso/OrElse

我试图得到一个延迟评估与’和’在我的Excel宏通过执行以下操作:
If Not myObject Is nothing *And* myObject.test() Then
    'do something'
Else
    'do something else'
End If

我知道懒惰的评价存在于VB.NET中作为AndAlso和OrElse,但在VBA中找不到类似的东西。如果在VBA中不存在延迟评估,那么结构化代码的最佳方式是什么,以便它将以我预期的方式进行评估?

唯一的短路(一种排序)是在case表达式求值,所以下面的ungainly语句做我认为你的要求;
Select Case True
    Case (myObject Is nothing),Not myObject.test()
        MsgBox "no instance or test == false"
    Case Else
        MsgBox "got instance & test == true"
    End Select
End Sub

相关文章

Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强...
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办...
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace...
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用...
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选...
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As Dat...