vite v6更新发现的有趣细节

大家好,我是农村程序员,独立开发者,前端之虎陈随易。

欢迎关注,广交朋友,共创未来。


最近呢,Vite 6 更新的消息,在各大技术博主的分享下,已经传开了。

我一直有关注软件更新的习惯,每天都会查看几次软件更新通知,vite 6 发布的第一时间,我就发现了。

粗看了几遍更新内容,不是我熟悉的,写文章分享的话,也只是囫囵吞枣,原样输出,说不出一些自己的见解出来。

不过,今天我又查看了一遍更新 vite 6 更新日志,发现了一个有趣的调整。

bash 复制代码
chore(deps)!: migrate fast-glob to tinyglobby

就是这一句话:把 fast-glob 替换为 tinyglobby

它们是干什么用的呢?参考以下例子:

tinyglobby

js 复制代码
import { glob, globSync } from 'tinyglobby';

await glob(['files/*.ts', '!**/*.d.ts'], { cwd: 'src' });
globSync(['src/**/*.ts'], { ignore: ['**/*.d.ts'] });

fast-glob

js 复制代码
const fg = require('fast-glob');

const entries = await fg(['.editorconfig', '**/index.js'], { dot: true });

// ['.editorconfig', 'services/index.js']

就是可以用类似正则一样的语法来查询文件和目录的工具。

顺着相关的链接追踪,看到这样一个已经关闭的 issue,翻译成中文就是:此 PR 建议用较轻的 tinyglobby 替换较重的 fast-glob。支持的模式相同,除了增加括号。

看到这里,不禁对开源贡献者的极客精神深深敬佩,之所以把 fast-glob 替换为 tinyglobby,就是为了减少一点项目的体积,提高一点性能。

那么接下来,我们对比一下 fast-globtinyglobby 的相关数据。

对比项 fast-glob tinyglobby
发布时间 2016年12月28日 2024年7月23日
依赖总数 17个 2个
体积大小 96.7 kB 15.9 kB
周下载量 4600万+ 20万+
最新更新 一年前 一个月前
贡献人数 30个 6个

作为前辈,fast-glob时间相关 的数据优势很大,比如 下载量

作为后辈,tinyglobby性能相关 的数据优势更大,比如 体积大小依赖数量

而且,目前 tinyglobby 已经被以上知名项目作为依赖使用,可靠性是毋庸置疑的。

我自己的开源项目 funpi(放屁) - Node.js接口开发框架,和 yite-cli - vue3脚手架 也会把 fast-glob 替换为 tinyglobby

  • funpi - https://github.com/chenbimo/funpi
  • yite-cli - https://github.com/chenbimo/yite-cli

如果你感兴趣,欢迎给个 star~

相关推荐
尘中客1 小时前
放弃 Echarts?前端直接渲染后端高精度 SVG 矢量图流的踩坑记录
前端·javascript·echarts·前端开发·svg矢量图·echarts避坑
FreeBuf_1 小时前
Chrome 0Day漏洞遭野外利用
前端·chrome
小彭努力中1 小时前
199.Vue3 + OpenLayers 实现:点击 / 拖动地图播放音频
前端·vue.js·音视频·openlayers·animate
2501_916007471 小时前
网站爬虫原理,基于浏览器点击行为还原可接口请求
前端·javascript·爬虫·ios·小程序·uni-app·iphone
前端大波2 小时前
Sentry 每日错误巡检自动化:设计思路与上手实战
前端·自动化·sentry
ZC跨境爬虫3 小时前
使用Claude Code开发校园交友平台前端UI全记录(含架构、坑点、登录逻辑及算法)
前端·ui·架构
慧一居士3 小时前
Vue项目中,何时使用布局、子组件嵌套、插槽 对应的使用场景,和完整的使用示例
前端·vue.js
2401_895521343 小时前
SpringBoot Maven快速上手
spring boot·后端·maven
Можно3 小时前
uni.request 和 axios 的区别?前端请求库全面对比
前端·uni-app
disgare3 小时前
关于 spring 工程中添加 traceID 实践
java·后端·spring