文章目录
本文简单介绍了 Happypack 的简单使用,不了解的同学可以进来看一看。也许会有所帮助。
Happypack 作用
在使用 Webpack 对项目进行构建时,会对大量文件进行解析和处理。当文件数量变多之后,Webpack 构件速度就会变慢。由于运行在 Node.js 之上的 Webpack 是单线程模型的,所以 Webpack 需要处理的任务要一个一个进行操作。
而 Happypack 的作用就是将文件解析任务分解成多个子进程并发执行。子进程处理完任务后再将结果发送给主进程。所以可以大大提升 Webpack 的项目构件速度
由于 JavaScript 是单线程模型,要想发挥多核 CPU 的能力,只能通过多进程去实现,而无法通过多线程实现。
本文项目代码地址:webpack-happypack-demo
欢迎 Star!
Happypack 的使用
Happypack 只是作用在 loader 上,使用多个进程同时对文件进行编译。
安装
$ npm install happypack --save-dev
使用(三步操作即可完成)
一、安装完成之后引入 HappyPack
webpack.config.js
const HappyPack = require('happypack');
module.exports = {
...
}
二、将常用的 loader
替换为 happypack/loader
webpack.config.js
const HappyPack = require('happypack');
module.exports = {
...
module: {
rules: [
test: /\.js$/,
// use: ['babel-loader?cacheDirectory'] 之前是使用这种方式直接使用 loader
// 现在用下面的方式替换成 happypack/loader,并使用 id 指定创建的 HappyPack 插件
use: ['happypack/loader?id=babel'],
// 排除 node_modules 目录下的文件
exclude: /node_modules/
]