# Supported Browsers The output of `wasm-bindgen` includes a JS file, and as a result it's good to know what browsers that file is expected to be used in! By default the output uses ES modules which isn't implemented in all browsers today, but when using a bundler (like Webpack) you should be able to produce output suitable for all browsers. Firefox, Chrome, Safari, and Edge browsers are all supported by `wasm-bindgen`. If you find a problem in one of these browsers please [report it] as we'd like to fix the bug! If you find a bug in another browser we would also like to be aware of it! ## Caveats * **IE 11** - `wasm-bindgen` by default requires support for `WebAssembly`, but no version of IE currently supports `WebAssembly`. You can support IE by [compiling wasm files to JS using `wasm2js`][w2js] (you can [see an example of doing this too](../examples/wasm2js.html)). Note that at this time no bundler will do this by default, but we'd love to document plugins which do this if you are aware of one! * **Edge** - the `TextEncoder` and `TextDecoder` APIs are not currently available in Edge which `wasm-bindgen` uses to encode/decode strings between JS and Rust. You can polyfill this with at least one of two strategies: 1. If using a bundler, you can likely configure the bundler to polyfill these types by default. For example if you're using Webpack you can use the [`ProvidePlugin` interface][wpp] like so after also adding [`text-encoding`] to your `package.json` ```js const webpack = require('webpack'); module.exports = { plugins: [ new webpack.ProvidePlugin({ TextDecoder: ['text-encoding', 'TextDecoder'], TextEncoder: ['text-encoding', 'TextEncoder'] }) ] // ... other configuration options }; ``` 2. If you're not using a bundler you can also include support manually by adding a `