vue-cli3 打包优化之 splitchunks详解

 更新时间:2023年07月06日 11:12:27   作者:DongFuPanda  
这篇文章主要介绍了vue-cli3 打包优化之 splitchunks的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

vue-cli3 打包优化之 splitchunks

Dllplugin 可以把常用库抽离出来,包括 vue,vuex之类的库。但是 ant design vue 是按需加载,且随时有可能引入新的组件,显然不适合放进 dll 中。直接和其他文件打进 vendor.js 有会很大,所以需要将其再单独抽离出来,我决定在 config.optimization.splitChunks 配置如下:

const IS_PROD = process.env.NODE_ENV === 'production'
module.exports = {
  chainWebpack(config) {
    if (IS_PROD) {
      config.optimization.splitChunks({
        cacheGroups: {
          common: {
            name: 'chunk-common', // 打包后的文件名
            chunks: 'initial', // 
            minChunks: 2,
            maxInitialRequests: 5,
            minSize: 0,
            priority: 1,
            reuseExistingChunk: true
          },
          vendors: {
            name: 'chunk-vendors',
            test: /[\\/]node_modules[\\/]/,
            chunks: 'initial',
            priority: 2,
            reuseExistingChunk: true,
            enforce: true
          },
          antDesignVue: {
            name: 'chunk-ant-design-vue',
            test: /[\\/]node_modules[\\/]ant-design-vue[\\/]/,
            chunks: 'initial',
            priority: 3,
            reuseExistingChunk: true,
            enforce: true
          }
        }
      })
    }
  }
}

关于 webpack4 的 splitChunks 还是有很多知识需要了解的,下文将进行简要的介绍。

splitChunks 常用参数

  • name 打包的 chunks 的名字
  • test 匹配到的模块奖杯打进这个缓存组
  • chunks 代码块类型 必须三选一: “initial”(初始化) | “all”(默认就是 all) | “async”(动态加载)默认 Webpack 4 只会对按需加载的代码做分割。如果我们需要配置初始加载的代码也加入到代码分割中,可以设置为 ‘all’
  • priority :缓存组打包的先后优先级,数值大的优先
  • minSize (默认是30000)形成一个新代码块最小的体积
  • minChunks (默认是1)在分割之前,这个代码块最小应该被引用的次数
  • maxInitialRequests (默认是3)一个入口最大的并行请求数
  • maxAsyncRequests(默认是5)按需加载时候最大的并行请求数
  • reuseExistingChunk 如果当前的 chunk 已被从 split 出来,那么将会直接复用这个 chunk 而不是重新创建一个
  • enforce 告诉 webpack 忽略 splitChunks.minSize, splitChunks.minChunks, splitChunks.maxAsyncRequests and splitChunks.maxInitialRequests,总是为这个缓存组创建 chunks

vue cli3安装教程

Vue CLI 3是一个基于Vue.js的标准化工具,用于快速构建Vue.js项目。它的安装非常简单,本文将介绍如何安装Vue CLI 3。

首先,我们需要确保已经安装了Node.js和npm。如果您还没有安装,请先下载并安装Node.js,然后npm也将自动安装。

接下来,我们可以使用以下命令安装Vue CLI 3:

npm install -g @vue/cli

这将全局安装Vue CLI 3,以后就可以在任何位置使用Vue CLI 3来创建Vue.js项目了。

安装完成后,您可以使用以下命令检查是否成功安装了Vue CLI 3:

vue --version

如果成功安装,则您应该能够看到Vue CLI 3的版本号。

现在,我们已经成功安装了Vue CLI 3,可以使用它来创建新的Vue.js项目了。您可以使用以下命令创建一个新的Vue.js项目:

vue create my-project

这将创建一个名为“my-project”的新Vue.js项目,并在其中初始化所有必需的文件和依赖项。

以上就是安装Vue CLI 3的简单教程。如果您想要更深入地了解Vue CLI 3的详细用法和功能,请查看Vue CLI 3的官方文档。

到此这篇关于vue-cli3 打包优化之 splitchunks的文章就介绍到这了,更多相关vue-cli3 打包优化内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue3版本网页小游戏设计思路

    vue3版本网页小游戏设计思路

    最近火爆全网的羊了个羊小程序,背景是根据官方介绍,“羊了个羊”是一款闯关消除小游戏,通关率不到0.1%。主要玩法为重叠的各类方块,需要在下方7个栏内完成消除,其特点就是“极难”,也因此成为热门挑战,对vue3版本网页小游戏设计思路感兴趣的朋友跟随小编一起看看吧
    2022-12-12
  • Vue动态组件表格的实现代码

    Vue动态组件表格的实现代码

    这篇文章主要介绍了Vue动态组件表格的实现代码,包括框架结构组件,文中还给大家封装了几个组件,有按钮组件、图片组件、滑动开关,结合示例代码给大家详细讲解,需要的朋友可以参考下
    2022-10-10
  • Vue路由守卫及页面登录权限控制的设置方法(两种)

    Vue路由守卫及页面登录权限控制的设置方法(两种)

    这篇文章主要介绍了Vue路由守卫及页面登录权限控制的设置方法,本文通过实例代码通过两种方法给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-03-03
  • vue图片转base64格式的方法示例

    vue图片转base64格式的方法示例

    对于前后端分离的项目,为了统一响应参数,需要将图片转换成base64的格式,下面这篇文章主要给大家介绍了关于vue图片转base64格式的相关资料,需要的朋友可以参考下
    2022-12-12
  • vue在IIS服务器部署后路由无法跳转

    vue在IIS服务器部署后路由无法跳转

    在IIS服务器上部署Vue项目时,可能会遇到路由无法正常跳转的问题,解决方法有两种,下面就来具体介绍一下解决方法,感兴趣的可以了解一下
    2024-10-10
  • Vue3导出pdf文件详细方案

    Vue3导出pdf文件详细方案

    这篇文章主要给大家介绍了关于Vue3导出pdf文件的相关资料,最近项目有个需求,将系统统计的数据生成分析报告,然后可以导出成PDF,这里给大家总结下,需要的朋友可以参考下
    2023-08-08
  • 解决vue-router 二级导航默认选中某一选项的问题

    解决vue-router 二级导航默认选中某一选项的问题

    今天小编就为大家分享一篇解决vue-router 二级导航默认选中某一选项的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • Vue解析带html标签的字符串为dom的实例

    Vue解析带html标签的字符串为dom的实例

    今天小编就为大家分享一篇Vue解析带html标签的字符串为dom的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • vue的插槽原来该这样理解

    vue的插槽原来该这样理解

    这篇文章主要为大家详细介绍了vue的插槽,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • Vue+Vite项目初建(axios+Unocss+iconify)的实现

    Vue+Vite项目初建(axios+Unocss+iconify)的实现

    一个好的项目开始搭建总是需要配置许多初始化配置,本文就来介绍一下Vue+Vite项目初建(axios+Unocss+iconify)的实现,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02

最新评论