Puisque la réponse est l'une des mieux classées dans Google, il suffit de chercher quelque chose comme vba if condition not lazy
Je voudrais donner un exemple plus simple, le problème et les solutions des deux conditions : AND
et le plus intéressant OR
...
Dim cond1 As Boolean 'some 1st condition that may be True or False
Dim obj As Collection 'just some sample object that may or may not be instantiated
(² : Je trouve qu'il est préférable d'expliquer aux autres devs, pourquoi vous n'avez pas choisi OR
s'ils ne connaissent pas le contexte)
le site AND
cas
cond1 = False
If cond1 Then Set obj = New Collection
problème :
If cond1 And obj.Count > 0 Then Debug.Print "Count > 0!" 'throws error if < cond1 = False >
'because condition 2 is always evaluated
solution :
If cond1 Then If obj.Count > 0 Then Debug.Print "Count > 0!" 'AND would not short-cicuit!² https://stackoverflow.com/a/57521572/1915920
Selon le goût, la complexité et la lisibilité, il peut être judicieux de l'écrire de cette façon :
If cond1 Then
If obj.Count > 0 Then 'AND would not short-cicuit!² https://stackoverflow.com/a/57521572/1915920
Debug.Print "Count > 0!"
End If
End If
le site OR
cas
cond1 = True
If Not cond1 Then Set obj = New Collection 'obj stays < Nothing > otherwise
problème :
If cond1 Or obj.Count = 0 Then Debug.Print "no objects!" 'throws error if < cond1 = True >
'because condition 2 is always evaluated
solution 1 :
une seule ligne en place, non redondante, sans GoTo
en utilisant Select
:
Select Case True: Case cond1, obj.Count = 0: Debug.Print "no objects!": End Select 'OR would not short-cicuit!² https://stackoverflow.com/a/57521572/1915920
au cas où il devrait/doit être sur plusieurs lignes et avec autre chose :
Select Case True
Case cond1, obj.Count = 0 'OR would not short-cicuit!² https://stackoverflow.com/a/57521572/1915920
Debug.Print "no objects!"
Case Else
Debug.Print "object count: " & obj.Count
End Select
solution 2 :
en place, du code non redondant avec un minimum d'efforts. GoTo
l'utilisation, mais plus longue If
-code à plusieurs lignes :
If cond1 Then
noObjs:
Debug.Print "no objects!"
ElseIf obj.Count = 0 Then 'OR would not short-cicuit!² https://stackoverflow.com/a/57521572/1915920
GoTo noObjs
End If
solution 3 :
en place, les conditions (peuvent s'adapter) sur une seule ligne, comme dans le cas de OR
-concaténation avec un certain nombre GoTo
l'usage :
If cond1 Then GoTo noObjs ElseIf obj.Count = 0 Then GoTo noObjs 'OR would not short-cicuit!² https://stackoverflow.com/a/57521572/1915920
GoTo skipOnAllFalse
noObjs:
Debug.Print "no objects!"
skipOnAllFalse: 'use more specific label/scenario name if possible
solution 4 :
code déplacé ( Sub
), en évitant GoTo
Les conditions peuvent tenir sur une seule ligne, mais le code du module/de la classe peut être plus illisible/étendu/encombré :
Private Sub noObjs(): Debug.Print "no objects!"
If cond1 Then noObjs ElseIf obj.Count = 0 Then noObjs 'OR would not short-cicuit!² https://stackoverflow.com/a/57521572/1915920
solution 5 :
en utilisant une seule variable de condition :
Dim any As Boolean: any = cond1
If Not any Then any = obj.Count = 0 'OR would not short-cicuit!² https://stackoverflow.com/a/57521572/1915920
If any Then Debug.Print "no objects!"
solution 6 :
en utilisant des variables de condition multiples :
Dim c1 As Boolean: Dim c2 As Boolean
c1 = cond1
If Not c1 Then c2 = obj.Count = 0 'OR would not short-cicuit!² https://stackoverflow.com/a/57521572/1915920
If c1 Or c2 Then Debug.Print "no objects!" 'safe to use Or now