Webpack plugin for generating an asset manifest.
NOTE: The following is related to the next major version of
webpack-manifest-plugin
, please check https://github.com/danethurber/webpack-manifest-plugin/blob/1.x/README.md forv1
documentation
npm install --save-dev webpack-manifest-plugin
In your webpack.config.js
var ManifestPlugin = require('webpack-manifest-plugin');
module.exports = {
// ...
plugins: [
new ManifestPlugin()
]
};
This will generate a manifest.json
file in your root output directory with a mapping of all source file names to their corresponding output file, for example:
{
"mods/alpha.js": "mods/alpha.1234567890.js",
"mods/omega.js": "mods/omega.0987654321.js"
}
// webpack.config.js
module.exports = {
output: {
publicPath
},
plugins: [
new ManifestPlugin(options)
]
}
Type: String
Default: manifest.json
The manifest filename in your output directory.
Type: String
Default: output.publicPath
A path prefix that will be added to values of the manifest.
Type: String
A path prefix for all keys. Useful for including your output path in the manifest.
Type: Boolean
Default: false
If set to true
will emit to build folder and memory in combination with webpack-dev-server
Type: Boolean
Default: false
If set to true
will group the manifest by entry. For example, an entry object of app
and store
with optimization.splitChunks
enabled will produce:
{
"app": {
"vendors~app.js": "/style/vendors~app.1234567890.js",
"app.js": "/style/app.0987654321.js"
},
"store": {
"vendors~app~store.js": "/style/vendors~app~store.1357913579.js",
"store.js": "/style/store.0246802468.js"
}
}
Type: Object
Default: {}
A cache of key/value pairs to used to seed the manifest. This may include a set of custom key/value pairs to include in your manifest, or may be used to combine manifests across compilations in multi-compiler mode. To combine manifests, pass a shared seed object to each compiler's ManifestPlugin instance.
Type: Function(FileDescriptor): Boolean
Filter out files. FileDescriptor typings
Type: Function(FileDescriptor): FileDescriptor
Modify files details before the manifest is created. FileDescriptor typings
Type: Function(FileDescriptor): number
Sort files before they are passed to generate
. FileDescriptor typings
Type: Function(Object, FileDescriptor): Object
Default: (seed, files) => files.reduce((manifest, {name, path}) => ({...manifest, [name]: path}), seed)
Create the manifest. It can return anything as long as it's serialisable by JSON.stringify
. FileDescriptor typings
Type: Function(Object): string
Default: (manifest) => JSON.stringify(manifest, null, 2)
Output manifest file in different format then json (i.e. yaml).
FileDescriptor {
path: string;
name: string | null;
isInitial: boolean;
isChunk: boolean;
chunk?: Chunk;
isAsset: boolean;
isModuleAsset: boolean;
}
Type: Chunk
Only available is isChunk
is true
Type: Boolean
Is required to run you app. Cannot be true
if isChunk
is false
.
Type: Boolean
Is required by a module. Cannot be true
if isAsset
is false
.
MIT © Dane Thurber