Appearance
Troubleshooting WebContainers
This page helps you troubleshoot issues with WebContainers.
Cannot load native addon
Currently, WebContainers can only execute languages that are natively supported on the Web, including JavaScript and WebAssembly. It is not possible to run native addons which are usually implemented using native languages such as C++, unless they can be compiled to WebAssembly. Therefore, loading native addons is disabled by default via --no-addons
in WebContainers. As a result, you may encounter an error that says: Cannot load native addon because loading addons is disabled
.
The solution to this is to use an alternative to the native addon which is either fully implemented in JavaScript or can be compiled to WebAssembly.
Fixing npm ERR! code ERESOLVE
With the release of native npm support, the npm
command in a terminal no longer defaults to turbo
but instead uses the real npm cli. There are a few differences in how npm
and turbo
resolve dependencies and one of them is how they work with peer dependencies. npm install
might now fail on your project with an error saying code ERESOLVE
or Conflicting peer dependency
. That's because npm now automatically installs peer dependencies by default. This feature was introduced in npm 7. You have three options to fix this error:
- Remove your
package-lock.json
file, re-runnpm install
, and save your project; or - Run
npm install --legacy-peer-deps
; or - Run
npm install --force
to bypass the conflicts.
Your project should load without your action, at least if dependencies are automatically installed. If an error is detected, StackBlitz will automatically re-run the installation step with npm install --legacy-peer-deps
. You can find more information on how to configure your project here.