• webpack5 - 之 生产环境的优化(dist压缩包、copy静态资源、缓存、代码切片、多线程打包、抽离重复代码 与 最小化 entry chunk)


    1:webpack5 - 之 生产环境 dist压缩包

    package.json

      "devDependencies": {
        "zip-webpack-plugin": "^4.0.1"
      },
    
    • 1
    • 2
    • 3

    webpack.pro.js

    const merge = require('webpack-merge');
    const baseConfig = require('./webpack.base');
    const ZipPlugin = require('zip-webpack-plugin') // 打包后 压缩dist
    
    const proConfig = {
      mode: 'production',
      devtool: 'hidden-source-map',
      plugins: [
        // 压缩 zip文件
        new ZipPlugin({
          // path: './', //路径名
          path: 'zip',
          filename: 'dist.zip' //打包名
        })
      ]
    }
    
    module.exports = merge(baseConfig, proConfig)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    npm run build效果

    在这里插入图片描述

    2:webpack5 - 之 生产环境 copy静态资源

    package.json

      "devDependencies": {
        "copy-webpack-plugin": "^11.0.0"
      },
    
    • 1
    • 2
    • 3

    webpack.pro.js

    const path = require('path')
    const merge = require('webpack-merge');
    const baseConfig = require('./webpack.base');
    const CopyWebpackPlugin = require('copy-webpack-plugin') // 复制静态资源的插件
    
    const proConfig = {
      mode: 'production',
      devtool: 'hidden-source-map',
      plugins: [
        new CopyWebpackPlugin({
          patterns: [{
            from: path.join(__dirname,'../public'),
            to: 'public',
            globOptions: {
              ignore: [
                '**/.*'
              ]
            }
          }]
        })
      ]
    
    }
    
    module.exports = merge(baseConfig, proConfig)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    npm run build效果

    在这里插入图片描述

    3:webpack5 - 之 测试环境 缓存

    webpack.dev.js

    • cache 缓存
    const merge = require('webpack-merge')
    const baseConfig = require('./webpack.base');
    const devConfig = {
      mode: 'development',
      // dev缓存
      cache: {
        type: 'memory'
      },
    }
    module.exports = merge(baseConfig, devConfig)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    npm run dev效果

    • 没加缓存前 2550ms
      在这里插入图片描述

    • 加缓存前 2402ms
      在这里插入图片描述

    4:webpack5 - 之 生产环境 缓存

    webpack.pro.js

    • cache 缓存
    const merge = require('webpack-merge');
    const baseConfig = require('./webpack.base');
    
    const proConfig = {
      mode: 'production',
      devtool: 'hidden-source-map',
      cache: {
        type: 'filesystem',
        buildDependencies: {
          config: [__filename]
        }
      },
    }
    
    module.exports = merge(baseConfig, proConfig)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    npm run build效果

    • 没有缓存前 2706ms
      在这里插入图片描述

    • 有缓存 2693ms
      在这里插入图片描述

    5:webpack5 - 之 生产环境 代码切片

    webpack.pro.js

    const path = require('path')
    const merge = require('webpack-merge');
    const baseConfig = require('./webpack.base');
    
    const proConfig = {
      mode: 'production',
      devtool: 'hidden-source-map',
      optimization: {
        // 代码切片
        splitChunks: {
          chunks: 'all',
        }
      },
      plugins: [
      ]
    }
    
    module.exports = merge(baseConfig, proConfig)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    npm run build效果

    • 没有切片前 4525ms
      在这里插入图片描述

    • 切片 4260ms
      在这里插入图片描述

    6:webpack5 - 之 多线程打包

    package.json

      "devDependencies": {
        "thread-loader": "^3.0.4"
      },
    
    • 1
    • 2
    • 3

    webpack.base.js

    • 加了 thread-loader 这个处理之
    const path = require('path')
    const MiniCssExtract = require('mini-css-extract-plugin') // css提取
    
    module.exports = {
      entry: {
        main: './src/main.js'
      },
      output: {
        publicPath: '',
        path: path.resolve(__dirname, '../dist'),
        filename: 'js/[name]_[contenthash:6].js',
      },
      // loader相关配置
      module: {
        rules: [{
            test: /\.(scss|css)$/, // 针对 .scss 或者 .css 后缀的文件设置 loader
            use: [
              // env.development ? 'style-loader' : 
              {
                loader: MiniCssExtract.loader
              },
              'css-loader',
              'postcss-loader',
              'sass-loader' // 使用 sass-loader 将 scss 转为 css
            ]
          },
          {
            test: /\.js$/,
            use: [
              {
                loader: 'babel-loader',
                options: {
                  cacheDirectory: true
                },
              },
              {
                loader: 'thread-loader',
                options: {
                  workers: 3,
                }
              }
            ],
            exclude: /node_modules/
          },
    
        ]
      },
      plugins: [
      ]
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 结论,当项目较小时,使用多进程打包反而造成打包时间延长,因为进程之间通信产生的开销比多进程能够节约的时间更长。

    7:webpack5 - 之 抽离重复代码 与 最小化 entry chunk

    webpack.pro.js

    const path = require('path')
    const merge = require('webpack-merge');
    const baseConfig = require('./webpack.base');
    
    const proConfig = {
      mode: 'production',
      devtool: 'hidden-source-map',
      cache: {
        type: 'filesystem',
        buildDependencies: {
          config: [__filename]
        }
      },
      optimization: {
        runtimeChunk: true, // 为运行时代码创建一个额外的 chunk,减少 entry chunk 体积,提高性能
        
        // 代码切片
        splitChunks: {
          chunks: 'all',
          // 重复打包问题
          cacheGroups:{
            vendors:{ // node_modules里的代码
              test: /[\\/]node_modules[\\/]/,
              chunks: "all",
              // name: 'vendors', 一定不要定义固定的name
              priority: 10, // 优先级
              enforce: true 
            }
          }
        }
      }
      plugins: [
      ]
    
    }
    
    module.exports = merge(baseConfig, proConfig)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37

    npm run build效果

    • 前 4408ms
      在这里插入图片描述

    • 后 4325ms
      在这里插入图片描述

  • 相关阅读:
    A-Level经济真题每期一练(54)
    【Docker】设置容器系统字符集zh_CN.UTF-8退出失效:关于Docker容器配置环境变量,再次进入失效问题
    Grafana dashboards as ConfigMaps
    【hexo】butterfly主题魔改之天气插件
    进程与线程的区别
    5 分钟速通 SVG
    创新科技改变城市:智慧城市建设全景展望
    基于java+springmvc+mybatis+vue+mysql的老年人健康饮食管理系统
    GEE错误——Tile error: Arrays must have same lengths on all axes but the cat axis
    基于SourceForge.net+Java+JMS技术实现的分布式爬虫系统
  • 原文地址:https://blog.csdn.net/weixin_43845137/article/details/126644951