Webpack 入口起点
单个入口语法
1 | // webpack.config.js |
也可以将一个文件路径数组传递给 entry
属性,这将创建一个所谓的 “multi-main entry”
1 | // webpack.config.js |
对象语法
用法:entry: { <entryChunkName> string | [string] } | {}
1 | // webpack.config.js |
对象语法会比较繁琐。然而,这是应用程序中定义入口的最可扩展的方式。
TIP
“webpack 配置的可扩展” 是指,这些配置可以重复使用,并且可以与其他配置组合使用。这是一种流行的技术,用于将关注点从环境(environment)、构建目标(build target)、运行时(runtime)中分离。然后使用专门的工具(如 webpack-merge)将它们合并起来。
TIP
当你通过插件生成入口时,你可以传递空对象
{}
给entry
。
描述入口的对象
用于描述入口的对象。你可以使用如下属性:
dependOn
: 当前入口所依赖的入口。它们必须在该入口被加载前被加载。filename
: 指定要输出的文件名称。import
: 启动时需加载的模块。library
: 指定 library 选项,为当前 entry 构建一个 library。runtime
: 运行时 chunk 的名字。如果设置了,就会创建一个新的运行时 chunk。在 webpack 5.43.0 之后可将其设为false
以避免一个新的运行时 chunk。publicPath
: 当该入口的输出文件在浏览器中被引用时,为它们指定一个公共 URL 地址。请查看 output.publicPath。
1 | // webpack.config.js |
runtime
和 dependOn
不应在同一个入口上同时使用
确保 runtime
不能指向已存在的入口名称
另外 dependOn
不能是循环引用的
常见场景
分离 app(应用程序) 和 vendor(第三方库) 入口
webpack.config.js
1 | module.exports = { |
webpack.prod.js
1 | module.exports = { |
webpack.dev.js
1 | module.exports = { |