files/en-us/webassembly/reference/javascript_interface/compilestreaming_static/index.md
The WebAssembly.compileStreaming() static method compiles a WebAssembly.Module directly from a streamed underlying source.
This function is useful if it is necessary to compile a module before it can be instantiated (otherwise, the WebAssembly.instantiateStreaming() function should be used).
[!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.
WebAssembly.compileStreaming(source)
WebAssembly.compileStreaming(source, compileOptions)
source
Response object or a promise that will fulfill with one, representing the underlying source of a Wasm module you want to stream and compile.compileOptions {{optional_inline}}
builtins {{optional_inline}}
"js-string", which enables JavaScript string builtins.importedStringConstants {{optional_inline}}
A Promise that resolves to a WebAssembly.Module object representing the compiled module.
source is not a Response or Promise resolving to a Response, the promise rejects with a {{jsxref("TypeError")}}.WebAssembly.CompileError.source is a Promise that rejects, the promise rejects with the error.source's Result has an error (e.g., bad MIME type), the promise rejects with an error.The following example (see our compile-streaming.html demo on GitHub, and view it live also) directly streams a Wasm module from an underlying source then compiles it to a WebAssembly.Module object. Because the compileStreaming() function accepts a promise for a Response object, you can directly pass it a Promise from calling fetch(), without waiting for the promise to fulfill.
const importObject = {
my_namespace: { imported_func: (arg) => console.log(arg) },
};
WebAssembly.compileStreaming(fetch("simple.wasm"))
.then((module) => WebAssembly.instantiate(module, importObject))
.then((instance) => instance.exports.exported_func());
The resulting module instance is then instantiated using
WebAssembly.instantiate(), and the exported function invoked.
This example enables JavaScript string builtins and imported global string constants when compiling the Wasm module with compileStreaming(), before instantiating it with instantiate() then 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.compileStreaming(fetch("log-concat.wasm"), compileOptions)
.then((module) => WebAssembly.instantiate(module, importObject))
.then((instance) => instance.exports.main());
{{Specifications}}
{{Compat}}