两个配置 将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开启)
                  },
                },
              },
            },
          },
        },

       
       
      })
    },
相关推荐
GISer_Jing2 天前
一次编码,七端运行:Taro多端统一架构深度解析与电商实战
前端·aigc·taro
光影少年17 天前
rn如何和原生进行通信,是单线程还是多线程,通信方式都有哪些
前端·react native·react.js·taro
杨进军18 天前
模拟 Taro 实现编译多端样式文件
前端·taro
GISer_Jing1 个月前
Taro跨端开发实战:JX首页实现_Trae SOLO构建
前端·javascript·aigc·taro
GISer_Jing1 个月前
Taro打造电商项目实战
前端·javascript·人工智能·aigc·taro
浅箬1 个月前
Taro3的H5项目在Android、IOS 中因为兼容性问题导致的白屏问题
android·团队开发·taro
GISer_Jing1 个月前
Taro跨端开发实战:核心原理与关键差异解析
前端·javascript·taro
GISer_Jing1 个月前
深入拆解Taro框架多端适配原理
前端·javascript·taro
静待雨落1 个月前
如何在Taro项目中使用axios
微信小程序·taro
GISer_Jing1 个月前
Taro+React跨端开发实战指南
react.js·arcgis·taro