Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sibiraj-s/replace-asset-name-webpack-plugin
Webpack Plugin to replace blocks with asset name matching given regex or string
https://github.com/sibiraj-s/replace-asset-name-webpack-plugin
replace-asset-names webpac-replace webpack webpack-plugin
Last synced: about 1 month ago
JSON representation
Webpack Plugin to replace blocks with asset name matching given regex or string
- Host: GitHub
- URL: https://github.com/sibiraj-s/replace-asset-name-webpack-plugin
- Owner: sibiraj-s
- License: mit
- Created: 2021-02-14T13:27:59.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2024-09-15T11:41:50.000Z (5 months ago)
- Last Synced: 2024-12-23T08:05:37.951Z (2 months ago)
- Topics: replace-asset-names, webpac-replace, webpack, webpack-plugin
- Language: JavaScript
- Homepage: https://npm.im/replace-asset-name-webpack-plugin
- Size: 699 KB
- Stars: 1
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# replace-asset-name-webpack-plugin
> Replace blocks with asset name matching given regex or string
[data:image/s3,"s3://crabby-images/132d9/132d9832a1849e3f2d1282dabea523c3a878d3fc" alt="Tests"](https://github.com/sibiraj-s/replace-asset-name-webpack-plugin/actions)
[data:image/s3,"s3://crabby-images/4869a/4869acf0dea8714b75ad6fd61f50593b6abf6ddc" alt="License"](https://github.com/sibiraj-s/replace-asset-name-webpack-plugin)
[data:image/s3,"s3://crabby-images/e4ef3/e4ef3d16a7536699e762bf1d0e1609b13e1b67b2" alt="Version"](https://npmjs.com/replace-asset-name-webpack-plugin)
[data:image/s3,"s3://crabby-images/d2e09/d2e09183efa9101e0973a057a7196e9814796af9" alt="Node Version"](https://npmjs.com/replace-asset-name-webpack-plugin)
[data:image/s3,"s3://crabby-images/5d6f0/5d6f0bc896aa8e88f2346c7414df840a05aeb32c" alt="Webpack Version"](https://webpack.js.org/)## Getting Started
### Installation
```bash
npm i -D replace-asset-name-webpack-plugin
# or
yarn add replace-asset-name-webpack-plugin --dev
```### Usage
```js
// webpack.config.js
const ReplaceAssetNamePlugin = require('replace-asset-name-webpack-plugin');module.exports = {
mode: 'production',
entry: {
main: 'src/index.js',
app: 'src/app.js',
},
output: {
filename: 'js/[name]-[contenthash].js',
},
plugins: [
new ReplaceAssetNamePlugin({
asset: /main(-.*)?.js$/,
rules: [
{
search: '{APP_ENTRY_REF}',
replace: /app(-.*)?.js$/,
},
],
}),
],
};
```This will replace the occurrence of `{APP_ENTRY_REF}` in `main.js` with the output chunk name of the `app` entry.
In development mode. If you use `contenthash` for testing. Make sure to enable [realContentHash](https://webpack.js.org/configuration/optimization/#optimizationrealcontenthash) so that chunk names will be updated after replace. This is enabled by default in production mode.
### Options
#### asset
Include all assets that pass test assertion
Type: `String|RegExp|Array`.
#### rules
Array of rules to search and replace assets
```js
new ReplaceAssetNamePlugin({
asset: /main(-.*)?.js$/,
rules: [
{
search: '{APP_ENTRY_REF}',
replace: /app(-.*)?.js$/,
},
],
});
```**search**
Type: `String|RegExp`
Replace the occurrence of given string or regex with the asset name
**replace**
Type: `String|RegExp`.
Name of the asset to be replaced with the matching search term
### Related Plugins
- [copy-asset-in-memory-webpack-plugin](https://github.com/sibiraj-s/copy-asset-in-memory-webpack-plugin)