Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/qwtel/html-webpack-combine-multiple-configs-plugin
This plugin allows script assets from multiple webpack configs to be injected into the same HTML template
https://github.com/qwtel/html-webpack-combine-multiple-configs-plugin
babel babel-env esmodules html-webpack-plugin plugin webpack
Last synced: 2 months ago
JSON representation
This plugin allows script assets from multiple webpack configs to be injected into the same HTML template
- Host: GitHub
- URL: https://github.com/qwtel/html-webpack-combine-multiple-configs-plugin
- Owner: qwtel
- License: mit
- Created: 2019-08-12T08:05:42.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-07T20:45:43.000Z (almost 2 years ago)
- Last Synced: 2024-10-12T09:46:09.995Z (3 months ago)
- Topics: babel, babel-env, esmodules, html-webpack-plugin, plugin, webpack
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/html-webpack-combine-multiple-configs-plugin
- Size: 701 KB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 29
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# HTML Webpack Combine Multiple Configs Plugin
This plugin allows script assets from multiple webpack configs to be injected into the same HTML template via `HtmlWebpackPlugin`.This is useful when using two babel-env targets for legacy and `esmodules` browsers. That's why this plugin can also alter script tags to include either `type="module"` or `nomodule`. This behavior is opt-in. See [examples](examples/example-basic) for more.
Note that you will also need a `nomodule` [fix for Safari 10.1](https://gist.github.com/samthor/64b114e4a4f539915a95b91ffd340acc) in that case.Based on [this gist](https://gist.github.com/robatwilliams/36a95119ae5adcd734a73f642f749cc3).
See [this issue](https://github.com/jantimon/html-webpack-plugin/issues/782) on GitHub for more.
Unlike the code found there, this plugin _does not_ contain a race condition that sometimes caused invalid HTML to be generated[^1].## Install
```bash
npm install --save-dev html-webpack-combine-multiple-configs-plugin
```or just [grab the source](https://unpkg.com/html-webpack-combine-multiple-configs-plugin) directly and modify it to your needs.
## Usage
```js
module.exports = [
{
...config1,
plugins: [
new HtmlWebpackPlugin(),
new HtmlWebpackCombineMultipleConfigsPlugin(),
],
},
{
...config2,
plugins: [
// Make sure each config has its own instance!
// Do not share plugins between configs!
new HtmlWebpackPlugin(),
new HtmlWebpackCombineMultipleConfigsPlugin(),
],
},
]
```## Compatibility
This library was tested against `[email protected]` only. Buyer beware.## Footnotes
[^1]: Technically it does contain the same race condition because it's outside the scope of this plugin to fix it. However, since this plugin waits for all configs to contribute their assets before proceeding to render the HTML, it won't matter in practice because the output will be the same regardless of which compilation finishes first. To be extra careful you can provide a unique `filename` to each `HtmlWebpackPlugin`.