Vue CLI 是一个基于 Vue.js 的脚手架工具,它可以帮助开发者快速搭建 Vue 应用程序。它提供了一系列的配置选项,可以让开发者快速搭建出一个完整的 Vue 应用程序。Vue CLI 使用 Webpack 来打包应用程序,并且还提供了一些有用的功能,如代码分割、CSS 预处理器、ESLint 等。
Webpack 是一个 JavaScript 打包工具,它可以将多个 JavaScript 文件打包成一个文件,减少 HTTP 请求数量,加快页面加载速度。Webpack 还可以将 CSS、图片等文件也进行打包,并且还可以使用 Babel 将 ES6 代码转换成 ES5 代码。Webpack 还有很多有用的功能,如代码分割、CSS 预处理器、ESLint 等。
const webpack = require('webpack'); const path = require('path'); module.exports = { entry: './src/index.js', // 入口文件 output: { // 输出文件相关配置 path: path.resolve(__dirname, 'dist'), // 输出文件存放地址 filename: 'bundle.js' // 输出文件名字 }, module: { // 针对不同的文件格式需要不同的loader来处理 例如css,js,imgage... }, plugins: [ // webpack 插件 ] }
调整 webpack 配置最简单的方式就是在 vue.config.js 中的 configureWebpack 选项提供一个对象:
// vue.config.js
module.exports = {
configureWebpack: {
plugins: [
new MyAwesomeWebpackPlugin()
]
}
}
该对象将会被 webpack-merge 合并入最终的 webpack 配置。
警告
有些 webpack 选项是基于 vue.config.js 中的值设置的,所以不能直接修改。例如你应该修改 vue.config.js 中的 outputDir 选项而不是修改 output.path;你应该修改 vue.config.js 中的 publicPath 选项而不是修改 output.publicPath。这样做是因为 vue.config.js 中的值会被用在配置里的多个地方,以确保所有的部分都能正常工作在一起。
如果你需要基于环境有条件地配置行为,或者想要直接修改配置,那就换成一个函数 (该函数会在环境变量被设置之后懒执行)。该方法的第一个参数会收到已经解析好的配置。在函数内,你可以直接修改配置,或者返回一个将会被合并的对象:
// vue.config.js
module.exports = {
configureWebpack: config => {
if (process.env.NODE_ENV === "production") {
// 为生产环境修改配置...
} else {
// 为开发环境修改配置...
}
}
}
Vue CLI 内部的 webpack 配置是通过 webpack-chain 维护的。这个库提供了一个 webpack 原始配置的上层抽象,使其可以定义具名的 loader 规则和具名插件,并有机会在后期进入这些规则并对它们的选项进行修改。
它允许我们更细粒度的控制其内部配置。接下来有一些常见的在 vue.config.js 中的 chainWebpack 修改的例子。
提示
当你打算链式访问特定的 loader 时,vue inspect 会非常有帮助。
// vue.config.js
module.exports = {
chainWebpack: config => {
config.module
.rule("vue")
.use("vue-loader")
.loader("vue-loader")
.tap(options => {
// 修改它的选项...
return options
})
}
}
提示
对于 CSS 相关 loader 来说,我们推荐使用 css.loaderOptions 而不是直接链式指定 loader。这是因为每种 CSS 文件类型都有多个规则,而 css.loaderOptions 可以确保你通过一个地方影响所有的规则。
// vue.config.js
module.exports = {
chainWebpack: config => {
// GraphQL Loader
config.module
.rule("graphql")
.test(/.graphql$/)
.use("graphql-tag/loader")
.loader("graphql-tag/loader")
.end()
// 你还可以再添加一个 loader
.use("other-loader")
.loader("other-loader")
.end()
}
}
如果你想要替换一个已有的基础 loader,例如为内联的 SVG 文件使用 vue-svg-loader 而不是加载这个文件:
// vue.config.js
module.exports = {
chainWebpack: config => {
const svgRule = config.module.rule("svg")
// 清除已有的所有 loader。
// 如果你不这样做,接下来的 loader 会附加在该规则现有的 loader 之后。
svgRule.uses.clear()
// 添加要替换的 loader
svgRule
.use("vue-svg-loader")
.loader("vue-svg-loader")
}
}
// vue.config.js
module.exports = {
chainWebpack: config => {
config
.plugin("html")
.tap(args => {
return []
})
}
}
你需要熟悉 webpack-chain 的 API 并阅读一些源码以便了解如何最大程度利用好这个选项,但是比起直接修改 webpack 配置,它的表达能力更强,也更为安全。
比方说你想要将 index.html 默认的路径从 /Users/username/proj/public/index.html 改为 /Users/username/proj/app/templates/index.html。通过参考 html-webpack-plugin 你能看到一个可以传入的选项列表。我们可以在下列配置中传入一个新的模板路径来改变它:
// vue.config.js
module.exports = {
chainWebpack: config => {
config
.plugin("html")
.tap(args => {
args[0].template = "/Users/username/proj/app/templates/index.html"
return args
})
}
}
你可以通过接下来要讨论的工具 vue inspect 来确认变更。
因为 @vue/cli-service 对 webpack 配置进行了抽象,所以理解配置中包含的东西会比较困难,尤其是当你打算自行对其调整的时候。
vue-cli-service 暴露了 inspect 命令用于审查解析好的 webpack 配置。那个全局的 vue 可执行程序同样提供了 inspect 命令,这个命令只是简单的把 vue-cli-service inspect 代理到了你的项目中。
该命令会将解析出来的 webpack 配置、包括链式访问规则和插件的提示打印到 stdout。
你可以将其输出重定向到一个文件以便进行查阅:
vue inspect > output.js
注意它输出的并不是一个有效的 webpack 配置文件,而是一个用于审查的被序列化的格式。
你也可以通过指定一个路径来审查配置的一小部分:
# 只审查第一条规则
vue inspect module.rules.0
或者指向一个规则或插件的名字:
vue inspect --rule vue
vue inspect --plugin html
最后,你可以列出所有规则和插件的名字:
vue inspect --rules
vue inspect --plugins
有些外部工具可能需要通过一个文件访问解析好的 webpack 配置,比如那些需要提供 webpack 配置路径的 IDE 或 CLI。在这种情况下你可以使用如下路径:
<projectRoot>/node_modules/@vue/cli-service/webpack.config.js
该文件会动态解析并输出 vue-cli-service 命令中使用的相同的 webpack 配置,包括那些来自插件甚至是你自定义的配置。
Vue.js2.0 开发插件插件通常会为Vue添加全局功能。插件的范围没有限制——一般有下面几种:添加全局方法或者属性,如:vue-eleme...
这节介绍TypeScript里的类型推论。即,类型是在哪里如何被推断的。基础TypeScript里,在有些没有明确指出类型的地方,类型推论会...
这节假设你已经了解了模块的一些基本知识 请阅读模块文档了解更多信息。模块解析就是指编译器所要依据的一个流程,用它来找出某...
Password defaultValue 属性 Password 对象定义和用法defaultValue 属性可设置或返回密码域的默认值。注意: 该默认值是在 HTML ...
CSS Padding(填充)CSS Padding(填充)属性定义元素边框与元素内容之间的空间。 Padding(填充) 当元素的 Padding(填充)(...