尤雨溪荷兰站:Vue11岁啦🎉

3,187 阅读3分钟

仔细看尤雨溪头上的帽子:

Void Zero是尤雨溪创办的新公司的名称,此次也是为了给自己公司背书。来看看 Vue11 年来所取得的成就吧:

  • 10k+ commis
  • 500+ releases
  • 2 million+ users worldwide
  • 250k+ GitHub Stars
  • ~6.4m weekly npm downloads
  • 1 billion+ monthly CDN requests on JSDelivr

而且这个趋势一直处于上涨状态:

image.png

Vue3.5 代号为:天元突破

SCR-20250319-mrth.png

  • 响应式性能提升
    • -56% 的内存占用
    • 读取长数组最高可有10倍提升
  • props 响应式解构
  • useTemplateRef
  • SSR 改善
    • Lazy Hydration
    • useId
  • defineCustomElement 的改善

去年10月份的 DevTools

image.png

接下来的 Vue3.6

SCR-20250319-mwfm.png

  • Alien Signals 来继续优化响应式性能
  • 无虚拟 DOM 模式
  • 重构 defineComponent 的类型
  • Rolldown + OXC 来打包

SCR-20250319-mxpo.jpeg

外星信号(Alien Signals):

SCR-20250319-mxos.png

  • 作者为 VolorVue Language Tools 的作者
  • 始于 Volor 自用实验
  • 性能超过已知所有 Signals 库(响应式库)

在跑分列表中位列第一:

SCR-20250319-mzhj.jpeg

这还没完,它的跑分还在随着版本的迭代越来越牛:

SCR-20250319-nain.jpeg

这里尤雨溪贴了一张原作者的推文:

SCR-20250319-namg.jpeg

翻译:我们刚刚发布了 0.6.0(直接跳过了 0.5.0)相比 0.4.8 而言提升了 13.4% 的性能并减少了 3.4% 的内存占用。

接下来就是和 Vue3.4 的对比:

SCR-20250319-nbvu.png

1.0 已合并至 Vue3.6 分支:

SCR-20250321-pkkz.png

紧接着便开始介绍起了无虚拟 DOM 模式:

SCR-20250321-plhx.png

为不熟悉这个模式的人简介下:

SCR-20250321-plwr.png

  • 同样的代码 不同的编译结果
  • 同样的 API 更快的性能 更少的内存占用
  • 接近 Solid.js 的性能
  • 与现有代码兼容(可以与虚拟 DOM 进行混用)

同样的代码编译成虚拟 DOM

SCR-20250321-qddf.png

同样的代码编译成无虚拟 DOM

SCR-20250321-qdtc.png

可以看到代码明显少了许多。接下来就是从Vue1到Vue3.6

image.png

推荐阅读:《尤雨溪:从Vue1到Vue3.6》

SCR-20250321-qfej.png

  • 懒计算 props / slots
  • 挂载 10 万个组件仅需 100 毫秒

在虚拟 DOM 模式和 Vapor 模式里最大程度的复用了 runtime-core 的代码以减少两者共存时的代码体积:

  • 共享组件实例类型
  • 复用生命周期、代码报错、provide / inject 等逻辑
  • 在虚拟 DOM 项目里使用 Vapor 模式仅增加约 3.5kb 的代码体积

SCR-20250325-pfpd.png

Vapor 模式的性能和 Solid 以及 Svelte5 在同一水平上:

  • 测试结果基于正在开发中的 Vapor 分支(未发布正式版)
  • 没有针对 benchmark 的跑分进行特殊优化

SCR-20250325-phqz.png

VDOMVapor 可以互相混用:

  • 可以在虚拟 DOM 组件里嵌入无虚拟 DOM 组件,反之亦然
  • PropsSlots 都能完美通用
  • 除了某些边界情况(并非 100% 兼容)

SCR-20250325-pktr.png

正在开发中:水合(Hydration

  • 复用服务端渲染函数的代码
  • 基础功能已开发完毕
  • 但需要更多的微调测试

SCR-20250325-pnwh.png

正在开发中:Transition组件

这个 edison1105 也是个国人,在南京工作:

SCR-20250325-pqhx.png

涉猎很广啊:vue.netnodetypescript

SCR-20250325-prlr.png

Vapor 待开发的功能:

  • 异步组件
  • 其他内置组件(KeepAliveSuspense)

SCR-20250325-pshc.png

3.6 就能用 Vapor 模式了:

  • 但还是实验性质的(并非正式版)
  • 可以通过 <script vapor> 来写无虚拟 DOM 组件
  • 可以通过 createVaporApp 来开启纯 Vapor 模式
  • 暂不支持但以后会支持:
    • <KeepAlive>
    • <Suspense>

SCR-20250325-pvoo.png

Vue 源码现在是由 Rolldowm + OXC 来打包的,速度有着惊人的提升:

Vue版本打包工具时间
3.2Rollup + rollup-plugin-typescript2 + terser114秒(慢102倍)
3.5Rollup + rollup-plugin-typescript2 + swc8.52秒(慢7.6倍)
3.6Rolldown + oxc-transform1.11秒

Vue Language Tools 3.0:

SCR-20250325-pzsm.png

Vue + Lynx = Vue Native?

SCR-20250325-qalo.png

Lynx 团队表示愿意与 Vue 合作:

SCR-20250325-qmvb.png

社区已经开干了:

SCR-20250325-qauq.png

往期精彩文章