configureWebpack、chainWebpack配置vue.config.js方式

 更新时间:2024年01月24日 15:46:02   作者:土豆Coder  
这篇文章主要介绍了configureWebpack、chainWebpack配置vue.config.js方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

引入问题

我们使用vue create waf-console-vue创建一个Vue项目时,新生成的项目我们可以看到在public/index.html中有这样的内容:

<title><%= htmlWebpackPlugin.options.title %></title>

Vue CLI 关于HTML和静态资源中有说明:

public/index.html文件是一个会被处理的模板html-webpack-plugin处理的模板。在构建过程中,资源链接会被自动注入。

所以我们会想到,这里使用变量的形式访问到的

htmlWebpackPlugin.options.title

也就是我们在创建项目的时候命名的项目名称,然后被脚手架Vue CLI构建项目时自动被处理模板写入了webpack配置中,那我们要如何修改这个配置项呢?

这就引出了问题:

我们如何在@vue-cli4vue.config.js文件中修改webpack中的这个配置项?

也就是如何修改这个值

htmlWebpackPlugin.options.title

修改htmlWebpackPlugin.options.title

因为新的脚手架vue不希望我们直接操作webpack配置文件,所以不再提供webpack.dev.js这样的文件了,如果我们想要修改webpack配置需要手动创建文件vue.config.js,那我们如何看默认项目已经配置好的webpack配置内容呢?

vue inspect > output.js

运行后项目中会自动生成一个文件output.js,这个就是当前项目的webpack配置内容

红框中我们看到title就是我们的项目名称,现在我们要修改这个值

// vue.config.js
module.exports = {
  chainWebpack: config => {
    config
      .plugin('html')
      .tap(args => {
        args[0].title = 'title test'
        return args
      })
  }
}

此时,重新启动项目npm run serve可以看到项目在浏览器中的title变成了我们设置的值title test,我们重新导出webpack的配置看看内容是不是改变了

vue inspect > output.js

到此为止我们就通过修改webpack配置改变了项目title值。

chainWebpack

从上面的应用实例中通过chainWebpack链式操作修改了webpack的配置,下面是几个利用链式操作修改的例子

修改Loader选项

这是修改之前的配置

// vue.config.js
module.exports = {
  chainWebpack: config => {
    config
      .plugin('html')
      .tap(args => {
        args[0].title = 'title test'
        return args
      })
    config.module
      .rule('vue')
      .use('vue-loader')
        .loader('vue-loader')
        .tap(options => {
          options.compilerOptions.whitespace = '' // 修改的地方
          return options
        })
  }
}

修改后我们inspect结果

总结:如果你想修改某个配置项的值我们都可以先使用inspect出webpack的配置内容,对应的每一项都有注释告诉我们应该如何书写

例如上面使用红框框出的

config.plugin('html')

以及

config.module.rule('vue').use('vue-loader')

添加Loader选项

module.exports = {
  chainWebpack: config => {
    config
      .plugin('html')
      .tap(args => {
        args[0].title = 'title test'
        return args
      })
    config.module
      .rule('vue')
      .use('vue-loader')
        .loader('vue-loader')
        .tap(options => {
          options.compilerOptions.whitespace = ''
          return options
        })
    // 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

如果你要替换某个规则的Loader,如果直接调用链式操作,只是在该规则下增加了一条Loader

所以正确的做法是先把这个规则已有的Loader都给删除,然后再加上自己的Loader,这里以svg为例,修改之前的内容是

module.exports = {
  chainWebpack: config => {
    const svgRule = config.module.rule('svg')
    svgRule.uses.clear() // 清除已有的所有loader
    svgRule
      .use('vue-svg-loader')
        .loader('vue-svg-loader')
    config
      .plugin('html')
      .tap(args => {
        args[0].title = 'title test'
        return args
      })
    config.module
      .rule('vue')
      .use('vue-loader')
        .loader('vue-loader')
        .tap(options => {
          options.compilerOptions.whitespace = ''
          return options
        })
    // 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()
  }
}

此时我们inspect结果

添加plugin

const NodePolyfillPlugin = require('node-polyfill-webpack-plugin')

module.exports = {
  chainWebpack: config => {
    config
    	.plugin('node-polyfill-webpack-plugin')
    	.use(NodePolyfillPlugin)
  }
}

此时我们inspect结果

configureWebpack

// vue.config.js
module.exports = {
  configureWebpack: config => {
    console.log(config)
  },
  chainWebpack: config => {
    console.log(config)
  }
}

通过打印出来的值可以看到结果一样,都是webpack的配置内容。

configureWebpack对象返回的值会被webpack-merge合并到最终的webpack配置中,如果你需要基于环境有条件的配置行为,或者想要直接修改配置,可以使用这个。

该方法的第一个参数就是已经解析好的配置,你可以直接修改配置,或者返回一个将会被合并的对象。

像这样:

// vue.config.js
module.exports = {
  configureWebpack: config => {
	  if (process.env.NODE_ENV === 'production') {
	    // 为生产环境修改配置
	  } else {
	    // 为开发环境修改配置
	  }
	}
}

总结

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

相关文章

  • Vuejs使用addEventListener的事件如何触发执行函数的this

    Vuejs使用addEventListener的事件如何触发执行函数的this

    这篇文章主要介绍了Vuejs使用addEventListener的事件触发执行函数的this方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • Vue3实现PDF文件解析与预览的完整实践

    Vue3实现PDF文件解析与预览的完整实践

    在实际的前端开发中,经常会碰到需要在线预览PDF文件的场景,比如后台管理系统查看合同、教育平台展示试卷、审批系统预览发票等等,所以本文给大家介绍了Vue3实现PDF文件解析与预览的完整实践,需要的朋友可以参考下
    2025-06-06
  • ElementUI年份范围选择器功能实现

    ElementUI年份范围选择器功能实现

    elementUI中有日期范围组件,月份范围选择的,就是没有年份范围选择的,需要加一个类似风格的,下面这篇文章主要给大家介绍了关于ElementUI年份范围选择器功能实现的相关资料,需要的朋友可以参考下
    2023-02-02
  • Vue 3 表格时间监控与动态后端请求触发详解 附Demo展示

    Vue 3 表格时间监控与动态后端请求触发详解 附Demo展示

    在Vue3中,使用el-table组件渲染表格数据,通过el-table-column指定内容,时间点需前端校准,用getTime()比较,到达时触发操作,异步API请求可用async/await处理,setInterval实现定时监控,配合条件判断防止重复请求
    2024-09-09
  • vuex的使用及持久化state的方式详解

    vuex的使用及持久化state的方式详解

    这篇文章主要介绍了vuex的使用及持久化state的方式详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • Vue3使用Vue Router实现前端路由控制

    Vue3使用Vue Router实现前端路由控制

    在现代Web应用中,前端路由控制是非常重要的一部分,它可以帮助我们将不同的页面内容展示给用户,同时保持用户在浏览不同页面时的连贯性,本文将介绍如何使用Vue Router来实现前端路由控制,需要的朋友可以参考下
    2024-10-10
  • 探讨Vue.js的组件和模板

    探讨Vue.js的组件和模板

    指令是Vue.js中一个重要的特性, 主要提供了一种机制将数据的变化映射为DOM行为。下面通过本文给大家分享Vue.js的组件和模板,需要的朋友参考下吧
    2017-10-10
  • Vue3+ElementPlus el-date-picker设置可选时间范围的示例代码

    Vue3+ElementPlus el-date-picker设置可选时间范围的示例代码

    在Vue3中使用Element Plus的el-date-picker组件设置可选时间范围,你可以使用disabled-date属性,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-07-07
  • Vue3+Ts实现缓存功能的示例代码

    Vue3+Ts实现缓存功能的示例代码

    这篇文章主要为大家详细介绍了Vue3+Ts如何实现缓存,用户搜索词本地排名,延迟消费或者消息队列,用户签到和锁,以及接口限流,还有全局ID等功能,需要的可以参考下
    2024-03-03
  • 关于Vue组件库开发详析

    关于Vue组件库开发详析

    这篇文章主要给大家介绍了关于Vue组件库开发的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用vue具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-07-07

最新评论