The WebAssembly.instantiate()
function allows you to compile and instantiate WebAssembly code. This function has two overloads:
Promise
resolves to both a compiled WebAssembly.Module
and its first WebAssembly.Instance
.WebAssembly.Module
and returns a Promise
that resolves to an Instance
of that Module
. This overload is useful if the Module
has already been compiled.Important: This method is not the most efficient way of fetching and instantiating wasm modules. If at all possible, you should use the newer WebAssembly.instantiateStreaming()
method instead, which fetches, compiles, and instantiates a module all in one step, directly from the raw bytecode, so doesn't require conversion to an ArrayBuffer
.
Promise<ResultObject> WebAssembly.instantiate(bufferSource, importObject);
Instance
, such as functions or WebAssembly.Memory
objects. There must be one matching property for each declared import of the compiled module or else a WebAssembly.LinkError is thrown.A Promise
that resolves to a ResultObject
which contains two fields:
module
: A WebAssembly.Module
object representing the compiled WebAssembly module. This Module
can be instantiated again, shared via postMessage() or cached in IndexedDB.instance
: A WebAssembly.Instance
object that contains all the Exported WebAssembly functions.TypeError
is thrown.WebAssembly.CompileError
, WebAssembly.LinkError
, or WebAssembly.RuntimeError
, depending on the cause of the failure.Promise<WebAssembly.Instance> WebAssembly.instantiate(module, importObject);
WebAssembly.Module
object to be instantiated.Instance
, such as functions or WebAssembly.Memory
objects. There must be one matching property for each declared import of module
or else a WebAssembly.LinkError is thrown.A Promise
that resolves to an WebAssembly.Instance
object.
TypeError
is thrown.WebAssembly.CompileError
, WebAssembly.LinkError
, or WebAssembly.RuntimeError
, depending on the cause of the failure.Note: You'll probably want to use WebAssembly.instantiateStreaming()
in most cases, as it is more efficient than instantiate()
.
After fetching some WebAssembly bytecode using fetch, we compile and instantiate the module using the WebAssembly.instantiate()
function, importing a JavaScript function into the WebAssembly Module in the process. We then call an Exported WebAssembly function that is exported by the Instance
.
var importObject = { imports: { imported_func: function(arg) { console.log(arg); } } }; fetch('simple.wasm').then(response => response.arrayBuffer() ).then(bytes => WebAssembly.instantiate(bytes, importObject) ).then(result => result.instance.exports.exported_func() );
Note: You can also find this example at index.html on GitHub (view it live also).
The following example (see our index-compile.html demo on GitHub, and view it live also) compiles the loaded simple.wasm byte code using the WebAssembly.compileStreaming()
method and then sends it to a worker using postMessage().
var worker = new Worker("wasm_worker.js"); WebAssembly.compileStreaming(fetch('simple.wasm')) .then(mod => worker.postMessage(mod) );
In the worker (see wasm_worker.js
) we define an import object for the module to use, then set up an event handler to receive the module from the main thread. When the module is received, we create an instance from it using the WebAssembly.instantiate()
method and invoke an exported function from inside it.
var importObject = { imports: { imported_func: function(arg) { console.log(arg); } } }; onmessage = function(e) { console.log('module received from main thread'); var mod = e.data; WebAssembly.instantiate(mod, importObject).then(function(instance) { instance.exports.exported_func(); }); };
Specification | Status | Comment |
---|---|---|
WebAssembly JavaScript Interface The definition of 'instantiate()' in that specification. | Working Draft | Initial draft definition. |
Desktop | ||||||
---|---|---|---|---|---|---|
Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | |
Basic support | 57 | 16 | 52
|
No | 44 | 11 |
Mobile | |||||||
---|---|---|---|---|---|---|---|
Android webview | Chrome for Android | Edge Mobile | Firefox for Android | Opera for Android | iOS Safari | Samsung Internet | |
Basic support | 57 | 57 | Yes
|
52
|
? | 11 | 7.0 |
Server | |
---|---|
Node.js | |
Basic support | 8.0.0 |
© 2005–2018 Mozilla Developer Network and individual contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/WebAssembly/instantiate