Vue.js 3.0 源码公布

10 月 5 日凌晨,Vue.js 框架的作者兼核心开发者尤雨溪公布了尚处于 Pre-Alpha 状态的 Vue 3 源码。

Vue.js 3.0 源码公布_第1张图片
说学不动的童鞋抓紧剩余的假期时间撸一遍源码吧 : D

作者表示,Vue 3 主要的架构改进、优化和新功能均已完成,剩下的主要任务是完成一些 Vue 2 现有功能的移植。

稳定版的具体发布时间尚未提及,不过根据 Vue 在 GitHub repo 公开展示的 Roadmap,后面应该还会发布 Alpha(计划于 Q4 发布)、Beta 等版本,所以至少要等到 2020 年 Q1 才有可能发布 3.0 稳定版。
Vue.js 3.0 源码公布_第2张图片
尤雨溪在去年发表的"Vue 3.0 Updates"主题演讲中曾强调过 Vue 3 包含的五个关键变化:
1.速度
2.体积
3.可维护性
4.面向原生
5.易用性
Vue.js 3.0 源码公布_第3张图片

下面了解一下针对 Vue 3 计划并已实现的主要架构改进和新功能:

  • 编译器(Compiler)
    • 使用模块化架构

    • 优化 "Block tree"

    • 更激进的 static tree hoisting 功能

    • 支持 Source map

    • 内置标识符前缀(又名 "stripWith")

    • 内置整齐打印(pretty-printing)功能

    • 移除 source map 和标识符前缀功能后,使用 Brotli 压缩的浏览器版本精简了大约 10KB

  • 运行时(Runtime)

    • 速度显著提升

    • 同时支持 Composition API 和 Options API,以及 typings

    • 基于 Proxy 实现的数据变更检测

    • 支持 Fragments

    • 支持 Portals

    • 支持 Suspense w/ async setup()

最后,还有一些 2.x 的功能尚未移植过来:
  • 服务器端渲染

  • Compiler DOM-specific transforms
    • v-on DOM 修饰符

    • v-model

    • v-text

    • v-pre

    • v-once

    • v-html

    • v-show

对了,还有与浏览器兼容性方面的问题,虽然去年尤雨溪曾提出会支持 IE11,但目前发布的 Pre-Alpha 版本打包后的代码是 ES2015+,并且【尚未】支持 IE11。
Vue.js 3.0 源码公布_第4张图片

至于与旧版本的兼容情况,因为 Vue 3.0 是主要版本,所以会包含一些重大变更。不过,开发组会非常重视兼容性问题,他们做了这样的保证:除了渲染函数 API 和作用域插槽语法之外的所有内容都将保持不变,或者通过兼容性构建让其与 2.x 保持兼容。

总的来说,Vue 3.0 虽然会对顶级 API 进行重大的修整,但依然会保持与 2.x 的兼容。此外,2.x 的最后一个次要版本将成为 LTS,并在 3.0 发布后继续享受 18 个月的 bug 和安全修复更新。

你可能感兴趣的:(Vue.js 3.0 源码公布)