WebAssembly.Tag
Das WebAssembly.Tag
-Objekt definiert einen Typ einer WebAssembly-Ausnahme, die an/von WebAssembly-Code geworfen werden kann.
Beim Erstellen einer WebAssembly.Exception
definiert das Tag die Datentypen und die Reihenfolge der von der Ausnahme transportierten Werte.
Die gleiche eindeutige Tag-Instanz muss verwendet werden, um die Werte der Ausnahme zuzugreifen (zum Beispiel bei der Verwendung von Exception.prototype.getArg()
).
Das Erstellen einer Instanz von Tag
erzeugt ein neues eindeutiges Tag.
Dieses Tag kann als Tag-Import an ein WebAssembly-Modul übergeben werden, wo es zu einem typisierten Tag wird, das im Tag-Abschnitt des WebAssembly-Moduls definiert ist.
Sie können auch ein in einem Modul definiertes Tag exportieren und verwenden, um Ausnahmen zu inspizieren, die vom Modul geworfen wurden.
Hinweis: Sie können nicht auf die Werte einer Ausnahme mit einem neuen Tag zugreifen, das nur zufällig die gleichen Parameter hat; es ist ein anderes Tag! Dies stellt sicher, dass WebAssembly-Module Ausnahmedaten bei Bedarf intern halten können. Der Code kann dennoch Ausnahmen abfangen und erneut werfen, die er nicht versteht.
Konstruktor
WebAssembly.Tag()
-
Erstellt ein neues
WebAssembly.Tag
-Objekt.
Instanzmethoden
Tag.prototype.type()
-
Gibt das Objekt zurück, das das Daten-Typen-Array für das Tag definiert (wie in seinem Konstruktor festgelegt).
Beispiele
Dieser Code-Schnipsel erstellt eine neue Tag
-Instanz.
const tagToImport = new WebAssembly.Tag({ parameters: ["i32", "f32"] });
Der folgende Schnipsel zeigt, wie wir es einem Modul example.wasm während der Instanziierung mittels eines "Import-Objekts" übergeben könnten.
const importObject = {
extmod: {
exttag: tagToImport,
},
};
WebAssembly.instantiateStreaming(fetch("example.wasm"), importObject).then(
(obj) => {
// …
},
);
Das WebAssembly-Modul könnte dann das Tag wie unten gezeigt importieren:
(module
(import "extmod" "exttag" (tag $tagname (param i32 f32))
)
Wenn das Tag verwendet wurde, um eine Ausnahme zu werfen, die nach JavaScript propagiert wurde, könnten wir das Tag verwenden, um dessen Werte zu inspizieren.
Hinweis: Es gibt viele Alternativen. Wir könnten das Tag auch verwenden, um eine WebAssembly.Exception
zu erstellen und diese von einer durch WebAssembly aufgerufenen Funktion werfen.
Spezifikationen
Specification |
---|
WebAssembly JavaScript Interface: Exception Handling # tag |
Browser-Kompatibilität
BCD tables only load in the browser