一文大白话讲清楚webpack基本使用——18——HappyPack

文章目录

一文大白话讲清楚webpack基本使用------18------HappyPack

1. 建议按文章顺序从头看,一看到底,豁然开朗

2. 啥是HappyPack

  • Happy,快乐,pack,打包,HappyPack,快乐打包,意思以前打包不快乐,为啥不快乐,以前打包用啥,webpack,webpack打包为啥不快乐
  • 因为webpack打包是单线程,但处理完这个再处理那个,所以不快乐
  • 那HappyPack怎么就快乐了呢,因为人家可以实现并行处理,同步处理这个和那个,你就说快不快乐吧
  • HappyPack可以将任务分解,派给多个子进程去处理,子进程处理完成后再将结果发送给主进程,从而减少构建时间

3. 怎么使用HappyPack

  • 我们以打包csss为例
  • 我们下载HappyPack插件,
js 复制代码
nom install happypack
  • 然后在webpack.config.js里面引入
js 复制代码
const HappyPack=require("happypack")
  • 然后做以下两件事
  1. 更改loader
  • 在使用HappyPack打包时,我们需要将对应的loader改为HappyPack/loader,通过id来指定
  • 比如我们之前处理css时使用style-loader和css-loader
js 复制代码
{
    test:/\.css$/,
        user:[MiniCssExtractPlugin.loader,'css-loader']
}
  • 使用HappyPack时改为使用happypack/loader?id=css-pack
js 复制代码
{
    test:/\.css$/,
        user:['happypack/loader?id=css-pack']
}
  • 然后在实例化的时候通过上面的idid=css-pack在指明我们这之前的loader->[MiniCssExtractPlugin.loader,'css-loader']
  1. 实例化happpack
  • 每实例化一个happypack相当于开启一个进程,这就是多进程去处理的表现。然后我们在实例化的时候,通过上面的idid=css-pack在指明我们这之前的loader->[MiniCssExtractPlugin.loader,'css-loader']
js 复制代码
 new HappyPack({
    id:'css-pack',//要更上面的id保持对应
    loaders:[MiniCssExtractPlugin.loader,'css-loader']
})
  • ok ,大功告成
  • 其他模块比如js等都类似,大家自行上手,不懂得留言
相关推荐
小码哥_常21 小时前
Kotlin类型魔法:Any、Unit、Nothing 深度探秘
前端
Web极客码1 天前
深入了解WordPress网站访客意图
服务器·前端·wordpress
幺风1 天前
Claude Code 源码分析 — Tool/MCP/Skill 可扩展工具系统
前端·javascript·ai编程
vjmap1 天前
唯杰地图CAD图层加高性能特效扩展包发布
前端·gis
ZC跨境爬虫1 天前
3D 地球卫星轨道可视化平台开发 Day7(AI异步加速+卫星系列精简+AI Agent自动评论)
前端·人工智能·3d·html·json
ID_180079054731 天前
淘宝 API 上货 / 商品搬家 业务场景实现 + JSON 返回示例
前端·javascript·json
M ? A1 天前
Vue 动态组件在 React 中,VuReact 会如何实现?
前端·javascript·vue.js·经验分享·react.js·面试·vureact
vipbic1 天前
独立开发复盘:我用 Uni-app + Strapi v5 肝了一个“会上瘾”的打卡小程序
前端·微信小程序
IT_陈寒1 天前
Vite的热更新突然失效,原来是因为这个配置
前端·人工智能·后端
ZC跨境爬虫1 天前
3D 地球卫星轨道可视化平台开发 Day8(分步渲染200颗卫星+ 前端分页控制)
前端·python·3d·重构·html