A webpack plugin for entry assets manifest. 一个生成入口资源清单的webpack插件
npm i -D assets-manifest-plugin
# or
yarn add -D assets-manifest-plugin
webpack.config.js
const AssetsManifestPlugin = require('assets-manifest-plugin');
module.exports = {
// ...
plugins: [
new AssetsManifestPlugin({
filename: 'manifest.js'
})
]
}
打包完成后会输出类似下面的一个文件:
dist/manifest.js
(function(root, factory) {
if (typeof exports === 'object' && typeof module === 'object') {
module.exports = factory();
} else if (typeof define === 'function' && define.amd) {
define(factory);
} else if (typeof exports === 'object') {
exports['ASSETS_MANIFEST'] = factory();
} else {
root['ASSETS_MANIFEST'] = factory();
}
})(typeof window !== 'undefined' ? window : this, function() {
return {
"main": {
"js": [
"js/runtime.6b509e0d.js",
"js/vendors.066af6ec2.js",
"js/main.5f10cd1d.js"
],
"css": [
"css/vendors.ac89822e.css",
"css/main.5ceab323.css"
]
}
}
});
- 类型:
'all' | Array<string>
- 默认:
'all'
- 描述: 需要生成资源清单的 entry 名,如果设置为
'all'
,表示生成全部入口资源清单
- 类型:
string
- 默认:
null
- 描述: 在生成的资源清单路径前加的一段路径,如果该项未配置,则会去使用
output.publicPath
的值
- 类型:
string
- 默认:
'manifest.js'
- 描述: 生成的入口清单文件名(可以带路径),如果是文件格式是
.js
,这会输出一个 UMD 模块文件,如果文件格式是.json
,则输出一个 JSON 文件,推荐生成 UMD 模块
- 类型:
'auto' | boolean
- 默认:
'auto'
- 描述: 是否压缩生成的资源清单文件,如果设置为
'auto'
,表示根据optimization.minimize
自动判断是否需要压缩
- 类型:
string
- 默认:
'ASSETS_MANIFEST'
- 描述: 生成 UMD 模块的全局变量名
- 类型:
boolean
- 默认:
false
- 描述: 是否禁用插件
- 类型:
boolean
- 默认:
true
- 描述: 是否将入口资源清单输出到文件
- 类型:
boolean
- 默认:
false
- 描述: 是否合并之前的资源清单数据(一般用于多个webpack任务打包时共用一份清单文件)
- 类型:
(manifest, mergedManifest) => void
- 默认:
null
- 描述: 当生成入口资源清单时,执行回调。回调参数是一个包含资源清单的 JSON 对象
- 类型:
boolean
- 默认:
true
- 描述: 当前是 devServer 模式时,自动设置 publicPath (
http://[ip]:[port]/[publicPath]
)