# webpack 相关
# 简单的配置方式
调整 webpack 配置最简单的方式就是在 creator.config.js
中的 configureWebpack
选项提供一个对象:
// creator.config.js
module.exports = {
configureWebpack: {
plugins: [
new MyAwesomeWebpackPlugin()
]
}
}
该对象将会被 webpack-merge (opens new window) 合并入最终的 webpack 配置。
警告
有些 webpack 选项是基于 creator.config.js
中的值设置的,所以不能直接修改。例如你应该修改 creator.config.js
中的 publicPath
选项而不是修改 output.publicPath
。这样做是因为 creator.config.js
中的值会被用在配置里的多个地方,以确保所有的部分都能正常工作在一起。
如果你需要基于环境有条件地配置行为,或者想要直接修改配置,那就换成一个函数 (该函数会在环境变量被设置之后懒执行)。该方法的第一个参数会收到已经解析好的配置。在函数内,你可以直接修改配置,或者返回一个将会被合并的对象:
// creator.config.js
module.exports = {
configureWebpack: config => {
if (process.env.NODE_ENV === 'production') {
// 为生产环境修改配置...
} else {
// 为开发环境修改配置...
}
}
}
# 链式操作 (高级)
Creator 内部的 webpack 配置是通过 webpack-chain (opens new window) 维护的。这个库提供了一个 webpack 原始配置的上层抽象,使其可以定义具名的 loader 规则和具名插件,并有机会在后期进入这些规则并对它们的选项进行修改。
它允许我们更细粒度的控制其内部配置。接下来有一些常见的在 creator.config.js
中的 chainWebpack
修改的例子。
提示
当你打算链式访问特定的 loader 时,autofe-scripts inspect 会非常有帮助。
# 修改 Loader 选项
// creator.config.js
module.exports = {
chainWebpack: config => {
config.module
.rule('css')
.use('css-loader')
.loader('css-loader')
.tap(options => {
// 修改它的选项...
return options
})
}
}
提示
对于 CSS 相关 loader 来说,我们推荐使用 css.loaderOptions 而不是直接链式指定 loader。这是因为每种 CSS 文件类型都有多个规则,而 css.loaderOptions
可以确保你通过一个地方影响所有的规则。
# 添加一个新的 Loader
// creator.config.js
module.exports = {
chainWebpack: config => {
// GraphQL Loader
config.module
.rule('graphql')
.test(/\.graphql$/)
.use('graphql-tag/loader')
.loader('graphql-tag/loader')
.end()
}
}
# 修改插件选项
// creator.config.js
module.exports = {
chainWebpack: config => {
config
.plugin('fork-ts-checker')
.tap(args => {
return [/* 传递给 fork-ts-checker-webpack-plugin's 构造函数的新参数 */]
})
}
}
你需要熟悉 webpack-chain 的 API (opens new window) 以便了解如何最大程度利用好这个选项,但是比起直接修改 webpack 配置,它的表达能力更强,也更为安全。
比方说你想要将 index.html
默认的路径从 */U
你可以通过接下来要讨论的工具 autofe-scripts inspect
来确认变更。
# 审查项目的 webpack 配置
因为 autofe-scripts
对 webpack 配置进行了抽象,所以理解配置中包含的东西会比较困难,尤其是当你打算自行对其调整的时候。
autofe-scripts
暴露了 inspect
命令用于审查解析好的 webpack 配置。
该命令会将解析出来的 webpack 配置、包括链式访问规则和插件的提示打印到 stdout。
你可以将其输出重定向到一个文件以便进行查阅:
autofe-scripts inspect > output.js
注意它输出的并不是一个有效的 webpack 配置文件,而是一个用于审查的被序列化的格式。
你也可以通过指定一个路径来审查配置的一小部分:
# 只审查第一条规则
autofe-scripts inspect module.rules.0
或者指向一个规则或插件的名字:
autofe-scripts inspect --rule vue
autofe-scripts inspect --plugin html
最后,你可以列出所有规则和插件的名字:
autofe-scripts inspect --rules
autofe-scripts inspect --plugins
# 以一个文件的方式使用解析好的配置
有些外部工具可能需要通过一个文件访问解析好的 webpack 配置,比如那些需要提供 webpack 配置路径的 IDE 或 CLI。在这种情况下你可以使用如下路径:
<projectRoot>/node_modules/autofe-scripts/webpack.config.js
该文件会动态解析并输出 autofe-scripts
命令中使用的相同的 webpack 配置。