WebAssembly.Global() Konstruktor
Baseline
Weitgehend verfügbar
Diese Funktion ist gut etabliert und funktioniert auf vielen Geräten und in vielen Browserversionen. Sie ist seit März 2020 browserübergreifend verfügbar.
Ein WebAssembly.Global() Konstruktor erstellt ein neues Global-Objekt, das eine Instanz einer globalen Variablen darstellt, die sowohl von JavaScript zugänglich als auch über ein oder mehrere WebAssembly.Module Instanzen importierbar/exportierbar ist.
Dies ermöglicht die dynamische Verknüpfung mehrerer Module.
Syntax
new WebAssembly.Global(descriptor, value)
Parameter
descriptor-
Ein Objekt, das zwei Eigenschaften enthält:
value-
Der Wert, den die Variable enthält. Dies kann jeder Wert sein, solange sein Typ mit dem Datentyp der Variablen übereinstimmt. Wenn kein Wert angegeben wird, wird ein typisierter
0-Wert verwendet, wenn der Wert vondescriptor.valueeiner deri32,i64,f32oderf64ist, undnullwird verwendet, wenndescriptor.valueexternrefoderanyfuncist.
Beispiele
>Erstellen einer neuen Global-Instanz
Das folgende Beispiel zeigt, wie eine neue globale Instanz mit dem WebAssembly.Global() Konstruktor erstellt wird.
Sie wird als veränderlicher i32-Typ definiert, mit einem Wert von 0.
Der Wert der globalen Variable wird dann geändert, zuerst auf 42 mit der Eigenschaft Global.value, und dann auf 43 mit der Funktion incGlobal(), die aus dem global.wasm Modul exportiert wird (diese addiert 1 zu jedem übergebenen Wert und gibt dann den neuen Wert zurück).
const output = document.getElementById("output");
function assertEq(msg, got, expected) {
const result =
got === expected
? `SUCCESS! Got: ${got}\n`
: `FAIL!\nGot: ${got}\nExpected: ${expected}\n`;
output.innerText += `Testing ${msg}: ${result}`;
}
assertEq("WebAssembly.Global exists", typeof WebAssembly.Global, "function");
const global = new WebAssembly.Global({ value: "i32", mutable: true }, 0);
WebAssembly.instantiateStreaming(fetch("global.wasm"), { js: { global } }).then(
({ instance }) => {
assertEq(
"getting initial value from wasm",
instance.exports.getGlobal(),
0,
);
global.value = 42;
assertEq(
"getting JS-updated value from wasm",
instance.exports.getGlobal(),
42,
);
instance.exports.incGlobal();
assertEq("getting wasm-updated value from JS", global.value, 43);
},
);
Hinweis: Sie können das Beispiel live auf GitHub ausführen; siehe auch den Quellcode.
Spezifikationen
| Spezifikation |
|---|
| WebAssembly JavaScript Interface> # dom-global-global> |
Browser-Kompatibilität
Siehe auch
globalDefinition- WebAssembly Übersicht
- WebAssembly-Konzepte
- Verwendung der WebAssembly JavaScript API