Import WebAssembly modules that expose the WebAssembly System Interface (WASI).
npm install --save-dev @wasm-tool/wasi
In JavaScript:
import("./example.wasm")
.then(exports => {
exports.someFunc();
});
Include the following rule in your webpack configuration:
{
// ...
module: {
rules: [
{
test: /\.wasm/,
type: "javascript/auto",
use: {
loader: "@wasm-tool/wasi"
}
}
]
}
// ...
}
We need to set the type
to JavaScript to bypass webpack's wasm support (as a workaround, for now). Which will also prevent the loading to work correclty in non-web environements.