webpack打包速度优化

自己项目上用的,记录一下,又能水一篇,嘿嘿~

1.编译时缓存、多线程loader:cache-loader、thread-loader

cache-loader用于避免项目资源的重复构建,如项目中的ts、tsx资源,在用babel-loader或者vue-loader编译前,先用cache-loader预处理一下,如果有缓存匹配的情况,则无需后面的loader对已有模块进行重复编译

配置方法:

arduino 复制代码
npm i cache-loader thread-loader
css 复制代码
// vue.config.js
module.exports = {
    configureWebpack: {
        module: {
          rules: [
            {
              test: /.(js|jsx)$/,
              include: [path.resolve('src')],
              use: ['cache-loader', 'thread-loader', 'babel-loader']
            }
          ]
        },
}

这里安装了thread-loader是一个多线程打包工具,与后面的terser-webpack-plugin很像,但他们负责的工作是不一样的,提前说明一下:

  1. thread-loader是一个 loader 插件,它可以利用多核处理器的优势将单个 loader 的工作分配给多个线程执行。这对于 CPU 密集型的任务来说非常有用,因为它可以让多个处理器核心同时处理任务,从而显著缩短编译时间。
  2. terser-webpack-plugin 是一个 webpack 插件,用于压缩和最小化 JavaScript 文件。它使用 TerserJS 来分析并优化代码,减小文件大小,从而使网站加载速度更快。

综上所述,两者都是有用的工具,但在不同方面发挥作用。thread-loader 主要用于加速构建过程,而 terser-webpack-plugin 用于压缩代码,加快页面加载速度。建议在使用 webpack 构建时,结合二者,先使用 thread-loader 加速构建过程,再使用 terser-webpack-plugin 压缩代码,从而提高整体性能。

2.压缩开启多线程插件:terser-webpack-plugin

terser-webpack-plugin的作用已在上述说明,下面只写我做的配置

ini 复制代码
// vue.config.js
const TerserPlugin = require("terser-webpack-plugin");
const os = require("os");
// 获取cpu核数
const threads = os.cpus().length;
​
module.exports = {
     optimization: {
      minimizer: [
        // 当生产模式会默认开启TerserPlugin,但是我们需要进行其他配置,就要重新写了
        new TerserPlugin({
          parallel: threads // 开启多进程
        })
      ]
    }
}

3.对打包进行整体缓存的插件:hard-source-webpack-plugin

hard-source-webpack-plugin 是一个 webpack 插件,它可以缓存模块、chunk 和模板,以便在后续构建中重用它们,从而加速 webpack 构建速度。它是通过创建一个映射表(map)来实现这一目标的,该映射表记录了模块及其输出位置之间的关系。当需要再次编译模块时,它可以从映射表中查找,而不是重新编译整个应用程序。通过这种方式,它减少了不必要的编译开销,并提高了构建速度,下面是我做的配置。

arduino 复制代码
// vue.config.js
const HardSourceWebpackPlugin = require('hard-source-webpack-plugin')
​
module.exports = {
     chainWebpack: (config) => {
        config.cache = {
          type: 'filesystem',
          allowCollectingMemory: true
        }
      },
     plugins: isProduction ? [compress, defer, new HardSourceWebpackPlugin({
      environmentHash: {
        root: process.cwd(),
        directories: [],
        // 设置要追踪的依赖,一旦发生变化将重新构建缓存包
        files: ['package-lock.json', '.env.test', 'package.json']
      },
      // 清除旧的缓存
      cachePrune: {
        // 设置清除超过一个月的缓存,防止占用硬盘过大
        maxAge: 30 * 24 * 60 * 60 * 1000
      }
    })]
}
相关推荐
崔庆才丨静觅7 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
passerby60618 小时前
完成前端时间处理的另一块版图
前端·github·web components
掘了8 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅8 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅9 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
崔庆才丨静觅9 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment9 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅9 小时前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端
剪刀石头布啊10 小时前
jwt介绍
前端
爱敲代码的小鱼10 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax