Skip to content

Extends the html-webpack-plugin to put resource tags as document.write() to enable pre execution of a script.

License

Notifications You must be signed in to change notification settings

mbenzenhoefer/html-webpack-dynamic-loader-plugin

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Dynamic Loader Plugin for html-webpack-plugin

An extension for the webpack plugin html-webpack-plugin.

What does the plugin do?

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>

Why?

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.

Installation

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

Basic Usage

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()
]

About

Extends the html-webpack-plugin to put resource tags as document.write() to enable pre execution of a script.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published