--- sidebar: auto --- # 配置参考 ## 全局 CLI 配置 有些针对 `@vue/cli` 的全局配置,例如你惯用的包管理器和你本地保存的 preset,都保存在 home 目录下一个名叫 `.vuerc` 的 JSON 文件。你可以用编辑器直接编辑这个文件来更改已保存的选项。 你也可以使用 `vue config` 命令来审查或修改全局的 CLI 配置。 ## 目标浏览器 请查阅指南中的[浏览器兼容性](../guide/browser-compatibility.md#browserslist)章节。 ## vue.config.js `vue.config.js` 是一个可选的配置文件,如果项目的 (和 `package.json` 同级的) 根目录中存在这个文件,那么它会被 `@vue/cli-service` 自动加载。你也可以使用 `package.json` 中的 `vue` 字段,但是注意这种写法需要你严格遵照 JSON 的格式来写。 这个文件应该导出一个包含了选项的对象: ``` js // vue.config.js module.exports = { // 选项... } ``` ### baseUrl 从 Vue CLI 3.3 起已弃用,请使用[`publicPath`](#publicPath)。 ### publicPath - Type: `string` - Default: `'/'` 部署应用包时的基本 URL。用法和 webpack 本身的 `output.publicPath` 一致,但是 Vue CLI 在一些其他地方也需要用到这个值,所以**请始终使用 `publicPath` 而不要直接修改 webpack 的 `output.publicPath`**。 默认情况下,Vue CLI 会假设你的应用是被部署在一个域名的根路径上,例如 `https://www.my-app.com/`。如果应用被部署在一个子路径上,你就需要用这个选项指定这个子路径。例如,如果你的应用被部署在 `https://www.my-app.com/my-app/`,则设置 `publicPath` 为 `/my-app/`。 这个值也可以被设置为空字符串 (`''`) 或是相对路径 (`'./'`),这样所有的资源都会被链接为相对路径,这样打出来的包可以被部署在任意路径,也可以用在类似 Cordova hybrid 应用的文件系统中。 ::: warning 相对 publicPath 的限制 相对路径的 `publicPath` 有一些使用上的限制。在以下情况下,应当避免使用相对 `publicPath`: - 当使用基于 HTML5 `history.pushState` 的路由时; - 当使用 `pages` 选项构建多页面应用时。 ::: 这个值在开发环境下同样生效。如果你想把开发服务器架设在根路径,你可以使用一个条件式的值: ``` js module.exports = { publicPath: process.env.NODE_ENV === 'production' ? '/production-sub-path/' : '/' } ``` ### outputDir - Type: `string` - Default: `'dist'` 当运行 `vue-cli-service build` 时生成的生产环境构建文件的目录。注意目标目录在构建之前会被清除 (构建时传入 `--no-clean` 可关闭该行为)。 ::: tip 提示 请始终使用 `outputDir` 而不要修改 webpack 的 `output.path`。 ::: ### assetsDir - Type: `string` - Default: `''` 放置生成的静态资源 (js、css、img、fonts) 的 (相对于 `outputDir` 的) 目录。 ::: tip 提示 从生成的资源覆写 filename 或 chunkFilename 时,`assetsDir` 会被忽略。 ::: ### indexPath - Type: `string` - Default: `'index.html'` 指定生成的 `index.html` 的输出路径 (相对于 `outputDir`)。也可以是一个绝对路径。 ### filenameHashing - Type: `boolean` - Default: `true` 默认情况下,生成的静态资源在它们的文件名中包含了 hash 以便更好的控制缓存。然而,这也要求 index 的 HTML 是被 Vue CLI 自动生成的。如果你无法使用 Vue CLI 生成的 index HTML,你可以通过将这个选项设为 `false` 来关闭文件名哈希。 ### pages - Type: `Object` - Default: `undefined` 在 multi-page 模式下构建应用。每个“page”应该有一个对应的 JavaScript 入口文件。其值应该是一个对象,对象的 key 是入口的名字,value 是: - 一个指定了 `entry`, `template`, `filename`, `title` 和 `chunks` 的对象 (除了 `entry` 之外都是可选的); - 或一个指定其 `entry` 的字符串。 ``` js module.exports = { pages: { index: { // page 的入口 entry: 'src/index/main.js', // 模板来源 template: 'public/index.html', // 在 dist/index.html 的输出 filename: 'index.html', // 当使用 title 选项时, // template 中的 title 标签需要是