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

       
       
      })
    },
相关推荐
Engss5 天前
taro RN 左右滑动切换页面
前端·javascript·react.js·taro
Lyda8 天前
uniapp vs taro3 vue 小程序动态渲染
javascript·微信小程序·taro
哈哈皮皮虾的皮9 天前
react和taro之间的关系
前端·react.js·taro
少恭写代码10 天前
使用duxapp开发 React Native App 事半功倍
react native·小程序·taro·duxapp
少恭写代码13 天前
duxapp:基于Taro使用模块化开发,提升开发效率
react native·小程序·taro·duxapp
谢尔登14 天前
【Taro】初识 Taro
taro
书边事.22 天前
Taro实现微信小程序自定义拍照截图识别
微信小程序·小程序·taro
游小北23 天前
Taro + Vue 的 CSS Module 解决方案
css·vue.js·taro
程序设计实验室24 天前
项目完成小结:使用DjangoStarter v3和Taro开发的微信小程序
微信小程序·django·taro·web前端·djangostarter
二豆是富婆1 个月前
taro ui 小程序at-calendar日历组件自定义样式+选择范围日历崩溃处理
小程序·taro