Vue.js项目中vue.config.js常用配置项介绍

 更新时间:2026年05月18日 16:21:55   作者:二川bro  
在VueCLI项目中,vue.config.js用于自定义构建、开发和部署流程,本文详细解析了其常用配置项,包括基础路径、开发服务器、Webpack配置、CSS预处理、插件选项及环境变量管理等,并,通过代码示例帮助开发者高效管理项目配置,提升开发体验

摘要

在 Vue CLI 创建的项目中,vue.config.js 是核心配置文件,用于定制化构建、开发和部署流程。本文详细解析了该文件的常用配置项,包括基础路径、开发服务器、Webpack 配置、CSS 预处理、插件选项及环境变量管理,并结合代码示例和表格说明,帮助开发者高效管理项目配置,提升开发体验。

关键词:Vue.js;vue.config.js;配置项;Webpack;开发服务器

一、引言

Vue CLI 是 Vue.js 官方提供的脚手架工具,它简化了 Vue.js 项目的搭建和开发流程。在 Vue CLI 创建的项目中,vue.config.js 是一个可选的配置文件,用于对 Vue CLI 项目进行自定义配置。通过该文件,开发者可以修改 Webpack 配置、配置开发服务器、设置静态资源路径、集成第三方插件等,以满足项目的特定需求。本文将详细介绍 vue.config.js 中常用的配置项,帮助开发者更好地理解和使用该文件。

二、基础配置项

(一)publicPath

  • 作用:设置应用的基础路径,即项目中静态资源的引用路径。它相当于 Webpack 中的 output.publicPath 配置。
  • 适用场景:当应用部署在子路径下(如 example.com/myapp/)或通过 CDN 提供静态资源时,需要设置该路径。
  • 示例代码
module.exports = {
  publicPath: process.env.NODE_ENV === 'production' ? '/myapp/' : '/'
};

(二)outputDir

  • 作用:指定构建输出目录,默认是 dist
  • 适用场景:当需要将构建文件输出到不同的目录中(如 CI/CD 流程或特定的文件结构需求)时,可以修改该配置。
  • 示例代码
module.exports = {
  outputDir: 'build'
};

(三)assetsDir

  • 作用:设置静态资源(如图片、字体、CSS)的子目录。
  • 适用场景:当需要对静态资源进行分类管理时,可以使用该配置。
  • 示例代码
module.exports = {
  assetsDir: 'assets'
};

(四)lintOnSave

  • 作用:决定在保存时是否启用 ESLint 检查。
  • 适用场景:在开发过程中,可以通过该配置控制代码检查的开启和关闭。

选项说明

  • true:启用 ESLint 检查。
  • false:禁用 ESLint 检查。
  • 'error':只有在 ESLint 报错时才中断构建。

示例代码

module.exports = {
  lintOnSave: true
};

(五)常用配置项表格总结

配置项类型默认值说明
publicPathString‘/’应用的基础路径
outputDirString‘dist’构建输出目录
assetsDirString‘’静态资源的子目录
lintOnSaveBoolean/Stringtrue是否启用 ESLint 检查

三、开发服务器配置项

(一)devServer

  • 作用:修改 Webpack DevServer 的设置,包括端口、热重载、代理等。

常用配置项

  • port:开发服务器的端口。
  • open:启动后是否自动打开浏览器。
  • hot:启用热模块替换(HMR)。
  • proxy:配置代理,用于解决开发环境中的跨域问题。

示例代码

module.exports = {
  devServer: {
    port: 8080,
    open: true,
    hot: true,
    proxy: {
      '/api': {
        target: 'http://localhost:5000',
        changeOrigin: true,
        pathRewrite: { '^/api': '' }
      }
    }
  }
};

(二)开发服务器配置项表格总结

配置项类型默认值说明
portNumber8080开发服务器的端口
openBooleanfalse启动后是否自动打开浏览器
hotBooleantrue是否启用热模块替换
proxyObject{}代理配置,用于解决跨域问题

四、Webpack 配置项

(一)configureWebpack

  • 作用:直接修改 Webpack 的配置,允许添加插件、修改模块解析等。
  • 适用场景:当需要对 Webpack 进行个性化修改时,可以使用该配置。

示例代码

module.exports = {
  configureWebpack: {
    plugins: [
      // 添加插件
    ],
    resolve: {
      alias: {
        '@': '/src' // 配置路径别名
      }
    }
  }
};

(二)chainWebpack

  • 作用:使用 webpack-chain 提供的链式 API,更细粒度地修改 Webpack 配置。
  • 适用场景:当需要对 Webpack 配置进行复杂的修改时,可以使用该配置。

示例代码

module.exports = {
  chainWebpack: config => {
    config.entry('app').add('./src/main.js');
    config.plugin('html').tap(args => {
      args[0].title = 'My Vue App';
      return args;
    });
  }
};

(三)Webpack 配置项表格总结

配置项类型默认值说明
configureWebpackObject/Function{}直接修改 Webpack 配置
chainWebpackFunction-使用链式 API 修改 Webpack 配置

五、CSS 配置项

(一)css

  • 作用:控制 CSS 相关的构建行为,包括 CSS 的模块化、是否提取 CSS 文件等。

常用配置项

  • extract:在生产环境中将 CSS 提取到单独的文件。
  • sourceMap:是否生成 CSS 源映射文件。
  • loaderOptions:配置各类 CSS 预处理器(如 SASS、LESS)的选项。

示例代码

module.exports = {
  css: {
    extract: true,
    sourceMap: false,
    loaderOptions: {
      sass: {
        prependData: `@import "~@/styles/variables.scss";`
      }
    }
  }
};

(二)CSS 配置项表格总结

配置项类型默认值说明
extractBooleantrue是否提取 CSS 到单独文件
sourceMapBooleanfalse是否生成 CSS 源映射文件
loaderOptionsObject{}配置 CSS 预处理器的选项

六、插件配置项

(一)pluginOptions

  • 作用:为第三方插件配置选项,Vue CLI 提供了很多插件,这些插件通常可以通过 pluginOptions 进行个性化配置。
  • 适用场景:当使用第三方插件时,需要为其提供额外的配置选项。

示例代码

module.exports = {
  pluginOptions: {
    'my-plugin': {
      someOption: true
    }
  }
};

(二)插件配置项表格总结

配置项类型默认值说明
pluginOptionsObject{}为第三方插件配置选项

七、环境变量配置项

(一)环境变量

  • 作用:根据不同的环境(开发、生产等)配置不同的设置。
  • 适用场景:当项目需要在不同的环境中运行时,可以通过环境变量来配置不同的设置。

示例代码

// .env.development
VUE_APP_TITLE = 'Development App'

// .env.production
VUE_APP_TITLE = 'Production App'

// vue.config.js
module.exports = {
  configureWebpack: config => {
    config.plugins.push(
      new webpack.DefinePlugin({
        'process.env.VUE_APP_TITLE': JSON.stringify(process.env.VUE_APP_TITLE)
      })
    );
  }
};

八、结论

vue.config.js 是 Vue CLI 项目中非常重要的配置文件,通过合理配置可以极大地提升项目的开发体验和维护效率。

本文详细介绍了 vue.config.js 中常用的配置项,包括基础配置、开发服务器配置、Webpack 配置、CSS 配置、插件配置和环境变量配置等。开发者可以根据项目的实际需求,选择合适的配置项进行配置,以满足项目的特定需求。

同时,建议开发者对 vue.config.js 进行版本控制,记录每次修改的原因和内容,便于回溯和协作。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue中使用echarts的示例

    vue中使用echarts的示例

    这篇文章主要介绍了vue中使用echarts的步骤,帮助大家更好的理解和使用vue框架,感兴趣的朋友可以了解下
    2021-01-01
  • Vue axios获取token临时令牌封装案例

    Vue axios获取token临时令牌封装案例

    这篇文章主要介绍了Vue axios获取token临时令牌封装案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • vue+echarts绘制折线图、柱状图和扇形图教程

    vue+echarts绘制折线图、柱状图和扇形图教程

    这篇文章主要介绍了vue+echarts绘制折线图、柱状图和扇形图教程,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • vue基于electron构建第一个程序

    vue基于electron构建第一个程序

    这篇文章主要为大家介绍了vue基于electron构建第一个程序过程详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • 面试题:react和vue的区别分析

    面试题:react和vue的区别分析

    这篇文章主要介绍了react和vue的区别分析,在面试中经常会遇到,小编通过实例文字相结合的形式给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-04-04
  • Vue响应式原理详解

    Vue响应式原理详解

    本篇文章主要介绍了Vue响应式原理详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • 使用vue构建一个上传图片表单

    使用vue构建一个上传图片表单

    这篇文章主要为大家详细介绍了使用vue构建一个上传图片表单,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • 详解Vue.js 作用域、slot用法(单个slot、具名slot)

    详解Vue.js 作用域、slot用法(单个slot、具名slot)

    这篇文章主要介绍了Vue.js 作用域、slot用法(单个slot、具名slot),本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-10-10
  • 简述vue路由打开一个新的窗口的方法

    简述vue路由打开一个新的窗口的方法

    这篇文章主要介绍了vue路由打开一个新的窗口的方法,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-11-11
  • 详解webpack+vue-cli项目打包技巧

    详解webpack+vue-cli项目打包技巧

    本篇文章主要介绍了详解webpack+vue-cli项目打包技巧 ,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06

最新评论