IsMissing-FunktionIsMissing function

Gibt einen booleschen Wert zurück, der angibt, ob ein optionales Variant - Argument an eine Prozedurübergeben wurde.Returns a Boolean value indicating whether an optional Variant argument has been passed to a procedure.

SyntaxSyntax

**** IsMissing (argname)IsMissing(argname)

Das erforderliche argname-Argument enthält den Namen eines optionalen Variant-Prozedurarguments.The required argname argument contains the name of an optional Variant procedure argument.

HinweiseRemarks

Verwenden Sie **** die IsMissing-Funktion, um zu ermitteln, ob beim Aufrufen einer Prozedur optionale Variant -Argumente angegeben wurden.Use the IsMissing function to detect whether or not optional Variant arguments have been provided in calling a procedure. **** IsMissing gibt true zurück, wenn kein Wert für das angegebene Argument übergeben wurde; Andernfalls wird falsezurückgegeben.IsMissing returns True if no value has been passed for the specified argument; otherwise, it returns False.

Wenn **** IsMissing true für ein Argument zurückgibt, kann die Verwendung des fehlenden Arguments in anderem Code zu einem benutzerdefinierten Fehler führen.If IsMissing returns True for an argument, use of the missing argument in other code may cause a user-defined error.

Wenn **** IsMissing für ein ParamArray -Argument verwendet wird, wird immer falsezurückgegeben.If IsMissing is used on a ParamArray argument, it always returns False. Um ein leeres ParamArrayzu erkennen, testen Sie, ob die obere Grenze des Arrays kleiner als die untere Grenze ist.To detect an empty ParamArray, test to see if the array's upper bound is less than its lower bound.

IsMissing funktioniert nicht bei einfachen Datentypen (z. B. Integer oder Double), da sie im Gegensatz zu Varianten nicht über eine Bereitstellung für ein "fehlendes" Flagbit verfügen.IsMissing does not work on simple data types (such as Integer or Double) because, unlike Variants, they don't have a provision for a "missing" flag bit. Daher ermöglicht Ihnen die Syntax für eingegebene optionale Argumente die Angabe eines Standardwerts.Because of this, the syntax for typed optional arguments allows you to specify a default value. Wenn das Argument beim Aufrufen der Prozedur ausgelassen wird, weist das Argument diesen Standardwert auf, wie im folgenden Beispiel dargestellt.If the argument is omitted when the procedure is called, the argument will have this default value, as in the following example.

    Sub MySub(Optional MyVar As String = "specialvalue")
        If MyVar = "specialvalue" Then
            ' MyVar was omitted.
        Else
        ...
    End Sub

In vielen Fällen können Sie den If MyVar Test vollständig auslassen, indem Sie den Standardwert auf den Wert MyVar festlegen, der enthalten sein soll, wenn der Benutzer ihn im Funktionsaufruf weglässt.In many cases you can omit the If MyVar test entirely by making the default value equal to the value you want MyVar to contain if the user omits it from the function call. Dadurch wird der Code präziser und effizienter.This makes your code more concise and efficient.

BeispielExample

In diesem Beispiel wird mithilfe der IsMissing -Funktion überprüft, ob ein optionales Argument an eine benutzerdefinierte Prozedur übergeben wurde.This example uses the IsMissing function to check if an optional argument has been passed to a user-defined procedure. Beachten Sie, dass Argumente vom Typ Optional jetzt Standardwerte und andere Typen als Variant aufweisen können.Note that Optional arguments can now have default values and types other than Variant.

Dim ReturnValue
' The following statements call the user-defined function procedure.
ReturnValue = ReturnTwice()    ' Returns Null.
ReturnValue = ReturnTwice(2)    ' Returns 4.

' Function procedure definition.
Function ReturnTwice(Optional A)
    If IsMissing(A) Then
        ' If argument is missing, return a Null.
        ReturnTwice = Null
    Else
        ' If argument is present, return twice the value.
        ReturnTwice = A * 2
    End If
End Function

Siehe auchSee also

Support und FeedbackSupport and feedback

Haben Sie Fragen oder Feedback zu Office VBA oder zu dieser Dokumentation?Have questions or feedback about Office VBA or this documentation? Unter Office VBA-Support und Feedback finden Sie Hilfestellung zu den Möglichkeiten, wie Sie Support erhalten und Feedback abgeben können.Please see Office VBA support and feedback for guidance about the ways you can receive support and provide feedback.