Vue CLI相关配置

Vue CLI 把 webpack、babel、postcss、dev-server 等工具链封装成「零配置」工具,但真实项目总有「自定义 loader、路径别名、代理转发、多环境差异」等需求。本文围绕一份渐进式的 vue.config.js,从本地开发到线上部署,逐条拆解每个配置项使用方法。

一、本地开发:devServer

1.反向代理跨域

js 复制代码
module.exports = {
  devServer: {
    port: 9527,
    host: '0.0.0.0',
    proxy: {
      '/api': {
        target: 'http://backend.test',
        changeOrigin: true,
        pathRewrite: { '^/api': '' }
      }
    }
  }
}
  • changeOrigin 解决后端对 Host 头的校验;
  • pathRewrite 把 /api/user 转成 /user,保持前端路径语义清晰。

2.mock 服务

js 复制代码
before: require('./mock/mock-server.js')

before 钩子在 webpack-dev-server 启动后执行,可在同端口启动本地 mock,无需额外服务。

二、构建输出:publicPath、outputDir、assetsDir

js 复制代码
module.exports = {
  publicPath: process.env.NODE_ENV === 'production'
    ? 'https://cdn.example.com/'
    : '/',
  outputDir: 'dist',
  assetsDir: 'static'
}
  • publicPath 决定 HTML 中资源引用的前缀;
  • outputDir 是打包后文件夹名称;
  • assetsDir 把 js / css / img 统一放到 static 子目录,方便 CDN 缓存。

三、运行时编译:runtimeCompiler 的利与弊

默认构建产物不包含模板编译器,体积减少 10 KB+。

若需在客户端使用 template 字符串,需显式开启:

js 复制代码
runtimeCompiler: true

代价是包变大、运行时性能下降,仅推荐后台管理系统或低代码平台开启。

四、按需转译:transpileDependencies 的深度用法

CLI 默认只转译 src 内的代码。当依赖包包含 ES6+ 语法且未提供 ES5 产物时,需要手动加入白名单:

js 复制代码
transpileDependencies: [
  'swiper',            // 包名
  /@some-scope\/.*/    // 正则匹配一个 scope
]

可显著减少 Babel 工作量,避免把 node_modules 全量拖慢构建。

五、深度定制:configureWebpack vs chainWebpack

1.configureWebpack:直接合并

js 复制代码
configureWebpack: {
  resolve: {
    alias: {
      '@': path.resolve(__dirname, 'src'),
      '@api': path.resolve(__dirname, 'src/api')
    }
  }
}

写法简单,但会覆盖同名配置,适合添加别名、plugin。

2.chainWebpack:链式修改

js 复制代码
chainWebpack: config => {
  config.plugin('define').tap(args => {
    args[0]['process.env.CUSTOM'] = JSON.stringify(process.env.CUSTOM)
    return args
  })
}

链式 API 粒度更细,可精准删除、替换 loader/plugin,适合高级场景。

六、CSS 模块化:requireModuleExtension 与 loaderOptions

js 复制代码
css: {
  requireModuleExtension: false,  // 去掉 *.module.css 强制后缀
  loaderOptions: {
    scss: {
      prependData: `@import "~@/styles/variables.scss";`
    }
  }
}

关闭扩展名后,所有 .scss 文件默认启用 CSS Modules;prependData 全局注入变量,避免每个文件重复 @import

七、Babel、ESLint、PostCSS

  • babel.config.js:CLI 只识别根目录文件,可配合 @babel/preset-envuseBuiltIns: 'usage' 自动 polyfill。
  • .eslintrc.js:使用 @vue/eslint-config-prettier 一键集成格式化;lintOnSave: false 可关闭保存时检查。
  • postcss.config.js:通过 autoprefixerpostcss-pxtorem 实现自动前缀与 px 转 rem。

八、多环境差异化

结合「模式与环境变量」机制,可在 vue.config.js 内动态返回配置:

js 复制代码
module.exports = {
  publicPath: process.env.VUE_APP_CDN || '/',
  productionSourceMap: process.env.NODE_ENV !== 'production'
}

配合 .env.staging.env.production,实现「本地开发用根路径,预发用 CDN,生产用 OSS」。

完整示例

js 复制代码
const path = require('path')
module.exports = {
  publicPath: '/',
  outputDir: 'dist',
  assetsDir: 'static',
  runtimeCompiler: false,
  transpileDependencies: ['swiper'],
  devServer: {
    port: 8080,
    proxy: { '/api': { target: 'http://localhost:3000', changeOrigin: true } }
  },
  css: {
    requireModuleExtension: false,
    loaderOptions: { scss: { prependData: `@import "~@/styles/var.scss";` } }
  },
  configureWebpack: {
    resolve: { alias: { '@': path.resolve(__dirname, 'src') } }
  },
  chainWebpack: config => {
    // 移除预加载,减少首屏请求
    config.plugins.delete('preload')
  }
}
相关推荐
YoungHong19924 小时前
面试经典150题[019]:最后一个单词的长度(LeetCode 58)
leetcode·面试·职场和发展
再学一点就睡6 小时前
初探 React Router:为手写路由筑牢基础
前端·react.js
悟空聊架构6 小时前
5 分钟上手!Burp 插件「瞎越」一键批量挖垂直越权
前端
麦麦大数据6 小时前
F010 Vue+Flask豆瓣图书推荐大数据可视化平台系统源码
vue.js·mysql·机器学习·flask·echarts·推荐算法·图书
炒毛豆6 小时前
vue3+antd实现华为云OBS文件拖拽上传详解
开发语言·前端·javascript
Pu_Nine_96 小时前
Axios 实例配置指南
前端·笔记·typescript·axios
红尘客栈26 小时前
Shell 编程入门指南:从基础到实战2
前端·chrome
完美世界的一天6 小时前
Golang 面试题「中级」
开发语言·后端·面试·golang
前端大卫7 小时前
Vue 和 React 受控组件的区别!
前端
Hy行者勇哥8 小时前
前端代码结构详解
前端