WebAssembly.JSTag
Die JSTag schreibgeschützte statische Eigenschaft der WebAssembly Schnittstelle ist ein eingebautes WebAssembly.Tag und repräsentiert Ausnahmen, die im JavaScript-Host ausgelöst werden — sie ermöglicht, dass Ausnahmen, die in JavaScript ausgelöst werden, von innerhalb eines Wasm-Moduls behandelt werden können.
Probieren Sie es aus
(module
(tag $js_tag (import "env" "js_tag") (param externref))
(import "env" "do_work" (func $do_work))
(import "env" "log" (func $log (param externref)))
(func $try_and_catch
(block $handler (result externref)
(try_table (catch $js_tag $handler)
;; Call a JS function that throws
(call $do_work)
)
(return)
)
;; The JS Error object is on the stack as an externref
;; Pass it back to JS for logging
(call $log)
)
(export "try_and_catch" (func $try_and_catch))
)
async function run() {
const { instance } = await WebAssembly.instantiateStreaming(
fetch("{%wasm-url%}"),
{
env: {
js_tag: WebAssembly.JSTag,
// This JS function throws, which Wasm will catch via JSTag
do_work: () => {
throw new Error("An exception was thrown in JS");
},
log: (error) => {
// errRef is the JS Error object passed back as an externref
console.log(error.message);
},
},
},
);
instance.exports.try_and_catch();
}
run();
Wert
Ein WebAssembly.Tag mit einem Typ von externref ((tag (param externref))).
Spezifikationen
| Spezifikation |
|---|
| WebAssembly JavaScript Interface> # dom-webassembly-jstag> |
Browser-Kompatibilität
Siehe auch
- WebAssembly Überblick
WebAssembly.Tag- tag Wasm-Definition