两个配置 将taro编译速度优化为原来的1/3

背景:

由于公司taro小程序项目比较庞大,每次启动编译都需要花费大约70s(加上sourceMap配置后接近90s),每次等待项目启动编译结束都是漫长的,同时由于涉及生产环境,项目版本框架都无法轻易升级。这里通过两个babel配置将二次编译速度缩减到20s左右。 优化前:

优化后:

注:

本文核心配置都借鉴自 cloud.tencent.com/developer/a...

1、使用到的plugin

  • progress-bar-webpack-plugin: 查看编译进度
  • speed-measure-webpack-plugin: 可以看到各个 loader、plugin 的构建时长,后续可针对耗时 loader、plugin 进行优化。

2、使用到的loader

  • thread-loader: 利用cpu多核,将耗时任务丢到单独的进程里执行 注意:thread-loader 只有在中大型项目中 提速效果才会比较明显,小型项目中甚至会让编译时间增长
  • cache-loader: 每个模块的处理结果缓存到磁盘上的文件中。当下一次构建时,如果模块的内容没有发生变化,cache-loader 将直接从缓存中读取处理结果,而不会再次执行相同的处理过程。这样可以避免重复的耗时操作,加速构建过程。

3、webpack中的配置方法 直接将cache-loader 和thread-loader 前面即可生效

java 复制代码
 module.exports = {
  // ...其他配置
  module: {
    rules: [
      {
        test: /\.js$/, // 指定需要使用 thread-loader 的文件类型
        use: [
          'cache-loader',
          'thread-loader', // 在这里添加 thread-loader
          // 其他 loader
          // 例如:'babel-loader'
        ],
      },
      // 其他规则
    ],
  },
};

二、在taro项目中如何进行配置 主要针对 webpack4,webpack5 优化非常简单可以直接搜索其他文章学习

遇到的问题:webpack4 匹配的 thread-loader和babel-loader版本都是2. 不指指定版本安最新版 会报 this.getOptions is not a function 的错误

  1. 找到taro框架合并后的webpack对象 地址 @tarojs/mini-runner/dis/index.js
  1. 断点查看合并后的 webpack格式
  1. 根据看到的格式,添加自己的配置
php 复制代码
 webpackChain: (chain, _webpack) => {
  <!-- 先删除  taro自带的babel配置-->
      chain.module.rules.delete('script')
      <!-- 在scss-loader之前加入cacheLoader 为什么这样配置,前面的参考原文中有讲述,不再赘述-->
       chain.module.rule('scss').oneOf('0').use('cacheLoader').loader('cache-loader').before('1')
      chain.module.rule('scss').oneOf('1').use('cacheLoader').loader('cache-loader').before('1')
      chain.merge({
        module: {
          rule: {
            script: {
              test: /\.[tj]sx?$/i,
              use: {
                threadLoader: {
                  loader: 'thread-loader', // 多核构建
                },
                babelLoader: {
                  loader: 'babel-loader',
                  options: {
                    cacheDirectory: true, // (除了可以是用cache-loader开启缓存也可以用过配置cacheDirectory: true开启)
                  },
                },
              },
            },
          },
        },

       
       
      })
    },
相关推荐
摸着石头过河的石头4 天前
taro3.x-4.x路由拦截如何破?
前端·taro
少恭写代码10 天前
duxapop 更新 2025-05-16 新增Svg编辑器 修复Svg多个Bug
小程序·taro
超级土豆粉14 天前
Taro Hooks 完整分类详解
前端·javascript·react.js·taro
少恭写代码15 天前
duxapp中主题系统是如何实现动态切换的
react native·小程序·移动开发·taro·duxapp
超级土豆粉21 天前
Taro 位置相关 API 介绍
前端·javascript·react.js·taro
zhuà!21 天前
taro+react重新给userInfo赋值后,获取的用户信息还是老用户信息
javascript·react.js·taro
超级土豆粉21 天前
Taro 网络请求相关 API 全面解析
网络·notepad++·taro
Feather_7425 天前
从Taro的Dialog.open出发,学习远程控制组件之【事件驱动】
javascript·学习·taro
faimi1 个月前
从Taro的Dialog.open出发,学习远程控制组件之【事件驱动】
taro·源码阅读