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
      }
    })]
}
相关推荐
TimelessHaze21 分钟前
拆解字节面试题:async/await 到底是什么?底层实现 + 最佳实践全解析
前端·javascript·trae
执键行天涯1 小时前
从双重检查锁定的设计意图、锁的作用、第一次检查提升性能的原理三个角度,详细拆解单例模式的逻辑
java·前端·github
青青子衿越1 小时前
微信小程序web-view嵌套H5,小程序与H5通信
前端·微信小程序·小程序
OpenTiny社区1 小时前
TinyEngine 2.8版本正式发布:AI能力、区块管理、Docker部署一键强化,迈向智能时代!
前端·vue.js·低代码
qfZYG1 小时前
Trae 编辑器在 Python 环境缺少 Pylance,怎么解决
前端·vue.js·编辑器
bug爱好者1 小时前
Vue3 基于Element Plus 的el-input,封装一个数字输入框组件
前端·javascript
Silence_xl1 小时前
RACSignal实现原理
前端
柯南二号2 小时前
【大前端】实现一个前端埋点SDK,并封装成NPM包
前端·arcgis·npm
dangkei2 小时前
【Wrangler(Cloudflare 的官方 CLI)和 npm/npx 的区别一次讲清】
前端·jvm·npm
乔公子搬砖2 小时前
小程序开发提效:npm支持、Vant Weapp组件库与API Promise化(八)
前端·javascript·微信小程序·js·promise·vagrant·事件绑定