A Webpack plugin for replace HTML contents with custom pattern string or regex.
Examples
https://github.com/iminif/html-replace-webpack-plugin-howto
Usage
First, install html-replace-webpack-plugin
as a development dependency:
npm install html-replace-webpack-plugin
Then, add it to your webpack.config.js
file:
In your webpack.config.js
file:
var webpack = require('webpack')
var HtmlReplaceWebpackPlugin = require('html-replace-webpack-plugin')
module.exports = {
plugin: [
new HtmlReplaceWebpackPlugin([
{
pattern: 'foo',
replacement: '`foo` has been replaced with `bar`'
},
{
pattern: '@@title',
replacement: 'html replace webpack plugin'
},
{
pattern: /(<!--\s*|@@)(css|js|img):([\w-\/]+)(\s*-->)?/g,
replacement: function(match, $1, type, file, $4, index, input)
{
var url = resource[type][file]
return $4 == undefined ? url : tpl[type].replace('%s', url)
}
}])
]
}
const resource = {
js: {'bootstrap': '//cdn/bootstrap/bootstrap.min.js'},
css: {'bootstrap': '//cdn/bootstrap/bootstrap.min.css'},
img:{'the-girl': '//cdn/img/the-girl.jpg'}
}
const tpl = {
img: '<img src="%s">',
css: '<link rel="stylesheet" type="text/css" href="%s">',
js: '<script type="text/javascript" src="%s"></script>'
}
In your src/index.html
file:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>@@title</title>
</head>
<body>
<div>foo</div>
</body>
</html>
After replacing, in the dist/index.html
file:
<html lang="en">
<head>
<meta charset="UTF-8">
<title>html replace webpack plugin</title>
<link rel="stylesheet" type="text/css" href="//cdn/bootstrap/bootstrap.min.css">
</head>
<body>
<div>`foo` has been replaced with `bar`</div>
<script type="text/javascript" src="//cdn/bootstrap/bootstrap.min.js"></script>
</body>
</html>
API
html-replace-webpack-plugin can be called with an objects array or an object.
Options for html-replace-webpack-plugin
new HtmlReplaceWebpackPlugin([obj1[, obj2[, obj3[, ...[, objN]]]]] | obj)
[obj1[, obj2[, obj3[, ...[, objN]]]]] | obj
Type: Objects Array
| Object
obj1, obj2, obj3, ..., objN | obj
Type: Object
obj.pattern
Type: String
| RegExp
string or regex pattern for matching HTML content. See the MDN documentation for RegExp for details.
obj.replacement
Type: String
| Function
string with which the matching string be replaced, or function which returns a string for replacing. See the MDN documentation for String.replace for details.