WebAssembly.instantiateStreaming()
Baseline
Widely available
*
This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2021.
* Some parts of this feature may have varying levels of support.
The WebAssembly.instantiateStreaming() static method compiles
and instantiates a WebAssembly module directly from a streamed underlying source. This
is the most efficient, optimized way to load Wasm code.
Note: Webpages that have strict Content Security Policy (CSP) might block WebAssembly from compiling and executing modules. For more information on allowing WebAssembly compilation and execution, see the script-src CSP.
Syntax
WebAssembly.instantiateStreaming(source)
WebAssembly.instantiateStreaming(source, importObject)
WebAssembly.instantiateStreaming(source, importObject, compileOptions)
Parameters
source-
A
Responseobject or a promise that will fulfill with one, representing the underlying source of a Wasm module you want to stream, compile, and instantiate. importObjectOptional-
An object containing the values to be imported into the newly-created
Instance, such as functions orWebAssembly.Memoryobjects. There must be one matching property for each declared import of the compiled module or else aWebAssembly.LinkErroris thrown. compileOptionsOptional-
An object containing compilation options. Properties can include:
builtinsOptional-
An array of strings that enables the usage of JavaScript builtins in the compiled Wasm module. The strings define the builtins you want to enable. Currently the only available value is
"js-string", which enables JavaScript string builtins. importedStringConstantsOptional-
A string specifying a namespace for imported global string constants. This property needs to be specified if you wish to use imported global string constants in the Wasm module.
Return value
A Promise that resolves to a ResultObject which contains two
fields:
module: AWebAssembly.Moduleobject representing the compiled WebAssembly module. ThisModulecan be instantiated again or shared via postMessage().instance: AWebAssembly.Instanceobject that contains all the Exported WebAssembly functions.
Exceptions
- If either of the parameters are not of the correct type or structure, a
TypeErroris thrown. - If the operation fails, the promise rejects with a
WebAssembly.CompileError,WebAssembly.LinkError, orWebAssembly.RuntimeError, depending on the cause of the failure.
Examples
>Instantiating streaming
The following example (see our instantiate-streaming.html
demo on GitHub, and view it live also)
directly streams a Wasm module from an underlying source then
compiles and instantiates it, the promise fulfilling with a ResultObject.
Because the instantiateStreaming() function accepts a promise for a Response
object, you can directly pass it a fetch()
call, and it will pass the response into the function when it fulfills.
const importObject = {
my_namespace: { imported_func: (arg) => console.log(arg) },
};
WebAssembly.instantiateStreaming(fetch("http://developer.mozilla.org/simple.wasm"), importObject).then(
(obj) => obj.instance.exports.exported_func(),
);
The ResultObject's instance member is then accessed, and the contained
exported function invoked.
Note:
For this to work, .wasm files should be returned
with an application/wasm MIME type by the server.
Enabling JavaScript builtins and global string imports
This example enables JavaScript string builtins and imported global string constants when compiling and instantiating the Wasm module with instantiateStreaming(), before running the exported main() function (which logs "hello world!" to the console). See it running live.
const importObject = {
// Regular import
m: {
log: console.log,
},
};
const compileOptions = {
builtins: ["js-string"], // Enable JavaScript string builtins
importedStringConstants: "string_constants", // Enable imported global string constants
};
WebAssembly.instantiateStreaming(
fetch("http://developer.mozilla.org/log-concat.wasm"),
importObject,
compileOptions,
).then((result) => result.instance.exports.main());
Specifications
| Specification |
|---|
| WebAssembly Web API> # dom-webassembly-instantiatestreaming> |
Browser compatibility
Loading…