今天来聊一聊前端的打包工具,以及未来期望

前端总是喜欢重复造轮子,很多库都是处于可以有,但没必要的存在,比如各式各样的UI组件库等。这两年的打包工具也是打得十分火热,各种号称速度提升多少多少倍的新工具,层出不穷。它们对实际的开发中真的有提升吗?应用场景是什么?今天就来缕一缕。

webpack

周下载量2千万。

作为打包工具的老大哥,虽然有很多新的打包工具号称要取代webpack,但是至今无人能够撼动其地位。其丰富的生态,是目前任何打包工具都无法比的。

webpack真的很慢吗?在webpack4.x之前,确实是这样的,由于基于js的打包,导致打包速度非常缓慢。但是webpack5.x之后,速度可以说是有质的提升。有了cache的加持,二次构建的时候,速度也可以非常快。再加上swc-loader的加入,替换掉传统的babel-loader,因其是rust开发的,打包速度更是惊人。

这也是出现了这么多新的打包工具时,webpack依旧能坐稳打包工具老大哥的宝座的原因。别人在进步的同时,webpack也在进步。

缺点:并不是开箱即用,要学习很多配置,增加了使用成本。

rollup

周下载量1.5千万。

如果不是vite带火了rollup,目前的人用rollup应该还是比较少的,其配置等和webpack相差不大,选择使用rollup并没有更多的好处,所以大家更愿意选择webpack而不是rollup。但因其对ES模块支持良好,而被vite团队采用。

在打包工具大战中,你可以看到新工具和webpack对比的,可以看到新工具和esbuild对比的。却几乎很少看到新工具很少和rollup对比的,有种上不了台面的感觉。从其打包能力来说,rollup也只适合中小型项目。

esbuild

周下载量1.9千万。

依稀记得esbuild横空出世,拉开了打包工具大战的序幕,让一个新的工具链vite出现在大家面前。其开箱即用的特性,也让打包变得不再是一件麻烦事。不过目前来说,还是很少人会直接用esbuild来打包项目。就连vite也只是让其来做开发环境下的预打包,而不是打包。虽然也是以esbuild-loader的形式出现在webpack中,但是那样使用的话,功劳又变成webpack了。

后面出现越来越多优秀的打包工具,esbuild似乎又有点不够看了。所以我对esbuild的未来期望是,能够成为vite的备胎活下去(dev),但是又很难闯出自己的天地。

turbopack

周下载量160万。

一款号称比webpack速度快700倍的打包工具,因为是用rust写的,速度自然不用说了。不过不管速度如何,噱头确实满满。加上有一个好爹------vercel,未来发展肯定是前途一片光明,肯定会成为开发react的标准打包工具。

但是很可惜,react/nextjs独享,vue开发者们就没这个福气了。

rspack

周下载量7万。

字节跳动出品,用于解决他们公司巨石应用时打包时速度慢的问题,也是用rust写的。vue开发者们,虽然turbopack没有享用,但是rspack却可以一试,其对vue支持。

比较尴尬的是,vue官方推荐vite开发,但是vite开发却难尽人意,因其打包工具用的是rollup,rollup又很慢,通常打包一个中型项目要花几分钟。rspack却能做到很快。

虽然rspack现在还很年轻,但是因其支持vue、react,并且兼容webpack的loader,各方面也是开箱即用,所以未来我还是挺看好rspack的。

farm

周下载量105。

也是一个用rust写的构建工具,和rspack差不多,兼容vite插件。不过在编译js这块,还是用的SWC。

重复的轮子太多了,未来我不太看好,估计作者写个一两年,发现没人用就弃坑了把。

parcel

周下载量14万。

一个上古时期的轻量化打包器,不过放在现在也没什么优势了,估计也是慢慢走下坡路。

snowpack

周下载量1万2。

前两年还火一阵子,但是随着各种各样的打包工具的出现,鱿鱼溪选择了vite,而snowpack本身也没什么优势,非常尴尬,作者就弃坑了。已经两年没更新了。

纠正一下网络上的错误

发现在谈论打包工具的时候,很多人会习惯性的把webpack和vite做对比,实际上工具链是工具链,打包工具是打包工具,两者还是不太能混为一谈的。毕竟vite只是整合了esbuild和rollup,本身没有做打包的事情。就连vite的官网都宣称自己是下一代的工具链,而非打包工具。这玩意就像是我整合了webpack,写了一个脚手架,然后说是写了一个打包工具一样别扭。

SWC是和babel平级的,SWC只处理js/jsx等相关的js文件,正如我们只会称babel为js编译器,而非打包工具一样,SWC也只是js编译器而非打包工具。

相关推荐
汪子熙25 分钟前
Angular 服务器端应用 ng-state tag 的作用介绍
前端·javascript·angular.js
杨荧26 分钟前
【JAVA开源】基于Vue和SpringBoot的旅游管理系统
java·vue.js·spring boot·spring cloud·开源·旅游
一 乐6 小时前
学籍管理平台|在线学籍管理平台系统|基于Springboot+VUE的在线学籍管理平台系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·学习
昨天;明天。今天。6 小时前
案例-表白墙简单实现
前端·javascript·css
安冬的码畜日常6 小时前
【玩转 JS 函数式编程_006】2.2 小试牛刀:用函数式编程(FP)实现事件只触发一次
开发语言·前端·javascript·函数式编程·tdd·fp·jasmine
小御姐@stella6 小时前
Vue 之组件插槽Slot用法(组件间通信一种方式)
前端·javascript·vue.js
GISer_Jing6 小时前
【React】增量传输与渲染
前端·javascript·面试
GISer_Jing6 小时前
WebGL在低配置电脑的应用
javascript
万叶学编程9 小时前
Day02-JavaScript-Vue
前端·javascript·vue.js