webpack优化构建速度示例-并行构建:

由于js的单线程特性,文件和任务时 要等待一个任务执行完成后执行下一个任务,但在实际开发中,很多任务是可以并行执行的(如同时处理多个不同js文件或同事压缩多张图片),一些loader和插件(thread-loader或happypack)提供了额外的并行处理能力

并行前
在这里插入图片描述

并行后
在这里插入图片描述

webpack.config.js
module.exports = {
    entry: './src/index.js',
    output: {
        filename: 'main.js',
    },
    // mode: 'production', // 或者 'production'
    module: {
        rules: [
            {
            test: /\.js$/i,
            exclude: /node_modules/,
            use: [
                {  
                    loader: 'thread-loader',  
                    options: {  
                      // 工作者数量,默认为 os.cpus().length - 1  
                      // 当设置为`true`时,它会自动匹配主机上的CPU核心数  
                      workers: 4, // 或者 true  
          
                      // 持久化worker,防止重新生成  
                    //   persistent: true,  
          
                      // 传递给工作线程的loader上下文  
                      // (默认: 传递给主线程的相同上下文)  
                      // pool: {}  
          
                      // 允许跨进程共享相同的node_modules  
                      // 将极大地提升编译速度  
                      // 默认为`true`  
                      // 注意:启用此选项将禁用`pool.name`和`pool.path`  
                    //   pool: {  
                    //     type: 'shared',  
                    //   },  
          
                      // 当使用持久化工作线程时,设置超时时间(毫秒)  
                      // 在空闲时杀死工作线程  
                      // 默认为5000(5秒)  
                    //   timeout: 2000,  
          
                      // 传递给工作线程的额外选项  
                      // (默认: 传递给主线程的相同选项)  
                      // options: {},  
                    },  
                  },  
                  {  
                    loader: 'babel-loader', // 需要并行处理的loader  
                    // ... 其他babel-loader配置  
                  }, 
            ]
        }
    ]
    },
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值