Dynamic Loader Plugin for html-webpack-plugin
An extension for the webpack plugin html-webpack-plugin.
The plugin converts plain JS/CSS resources in HTML to be dynamically loaded by JS. Example:
<script type="text/javascript" src="anyfile.js"></script>
becomes
<script type="text/javascript">
document.write('<script type="text/javascript" src="anyfile.js"></script>');
</script>
In my case I needed to run JS before any of these files was loaded to get the correct base href for my angular application due to the fact that I need to deploy the same artifact on any stage. So this helps me to execute some JS logic to determine the base href before loading the scripts.
You must be running webpack >= 2 on node 4 or higher
Install the plugin with npm:
$ npm install --save-dev html-webpack-dynamic-loader-plugin
Require the plugin in your webpack config:
var HtmlWebpackDynamicLoaderPlugin = require('html-webpack-dynamic-loader-plugin');
Add the plugin to your webpack config as below:
plugins: [
new HtmlWebpackPlugin(),
new HtmlWebpackDynamicLoaderPlugin()
]
If the configuration is left empty, nothing will be done. You need to set the parameter dynamicLoad as regEx-Pattern to select the files to be loaded dynamically.
plugins: [
new HtmlWebpackPlugin({
// any further config
dynamicLoadResources: '.js$'
}),
new HtmlWebpackDynamicLoaderPlugin()
]