Funkce IIf

Vrátí jeden ze dvou možných výsledků funkce, v závislosti na logické hodnotě vyhodnoceného výrazu.

Syntaxe:


IIf (Bool As Boolean, Variant1 As Variant, Variant2 As Variant) As Variant

Parametry:

Bool: Any expression that you want to evaluate. If the expression evaluates to True, the function returns the value of Variant1, otherwise it returns the value of Variant2.

Variant1, Variant2: Any expression, one of which will be returned as the function result, depending on the logical evaluation.

note

IIf evaluates both Variant1 and Variant2 even if it returns only one of them. If one of the expressions results in error, the function returns the error. For example, do not use IIF to bypass a possible division by zero result.


Chybové kódy:

5 Neplatné volání procedury

Příklad:


REM Vrátí maximum ze 3 hodnot
Function Max (A As Double, B As Double, C, As Double) As Double
    Max = IIf( A >= B, A, B)
    Max = IIf( C >= Max, C, Max)
End Function
REM Špatné použití funkce IIf
Function Inverse(A As Double) As Double
    Inverse = IIf( A = 0, 0, 1/A )
End Function

Příkaz If nebo Select Case

Funkce Switch