vue2 打包生成的js文件过大优化

在Vue项目中,打包生成的JS文件过大通常是由于多种因素造成的,包括但不限于第三方库过大、冗余代码、未压缩的资源等。下面是一些优化Vue项目打包后JS文件大小的常见方法:

1.代码分割 chunk

使用Webpack的代码分割功能,可以将代码分割成多个小的chunk,实现按需加载。

2.启用 Gzip/Brotli 压缩

打包时生成 Gzip 文件(需安装 compression-webpack-plugin

复制代码
npm install compression-webpack-plugin --save-dev

npm install path --save-dev

在vue.config.js中配置

复制代码
const path = require('path')  // 引入path模块
const CompressionWebpackPlugin = require('compression-webpack-plugin');

module.exports = {
 // 关闭生产环境sourceMap(减少50%+体积)
  productionSourceMap: false,

  configureWebpack: { // 配置webpack的字段。
    //打包忽略第三方库
    externals:envBoole ? cdn.externals : {},
    //  开启代码分割
    optimization: {
      splitChunks: {
        chunks: 'all',
        minSize: 20000, // 最小chunk size 20KB
        maxSize: 244000, // 超过244KB自动拆分
        cacheGroups: {
          vendor: {
              test: /[\/]node_modules[\/]/,
              name(module) {
                  // 提取node_modules中的包名作为chunk名
                  const packageName = module.context.match(/[\/]node_modules[\/](.*?)([\/]|$)/)[1];
                  // 兼容npm包名中的@符号
                  return `npm.${packageName.replace('@', '')}`;
              },
              priority: 10,
              reuseExistingChunk: true,
          },
          // 拆分公共组件
          common: {
              name: 'common',
              minChunks: 2,
              priority: 5,
              reuseExistingChunk: true
          }
        }
      }
    },
    //  开启gzip压缩
    plugins: [
      new CompressionWebpackPlugin({
        filename: '[path].gz[query]',
        algorithm: 'gzip',
        test: new RegExp('\\.(' + ['js', 'css'].join('|') + ')$'),
        threshold: 10240,
        minRatio: 0.8
      })
    ]
  },

}
相关推荐
IT凝冬几秒前
liunx 的 centos7 安装ngin
前端
赵锦川1 分钟前
大屏比例缩放
前端·javascript·html
于慨32 分钟前
tauri
java·服务器·前端
riyue66639 分钟前
封装 WebSocket 工具类
网络·vue.js·websocket·网络协议·v
贼爱学习的小黄1 小时前
NC BIP参照开发
java·前端·nc
小江的记录本1 小时前
【MyBatis-Plus】MyBatis-Plus的核心特性、条件构造器、分页插件、乐观锁插件
java·前端·spring boot·后端·sql·tomcat·mybatis
光影少年1 小时前
如何进行前端性能优化?
前端·性能优化
Dxy12393102161 小时前
js如何把字符串转数字
开发语言·前端·javascript
爱写bug的野原新之助2 小时前
爬虫之补环境:加载原型链
前端·javascript·爬虫
陈广亮2 小时前
工具指南7-Unix时间戳转换工具
前端