Composition API RFC
不得不说,vue的语法,越来越react了,感觉vue3发布后,会有更多人专项react了
vue2实现计算属性和点击累加的代码就不看了,大家都会,看下vue3的
我们执行npm run dev 调试打个包
1 |
|
这个reactive和react-hooks越来越像了, 大家可以去Composition API RFC这里看细节
功能
编译器(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 的功能尚未移植过来,如下:
- 服务器端渲染
- keep-alive
- transition
- Compiler DOM-specific transforms
- v-on DOM 修饰符 v-model v-text v-pre v-onc v-html v-show
typescript
全部由typescript构建,我们学的TS热度++ 三大库的最终选择,ts乃今年必学技能
proxy取代deineProperty
除了性能更高以为,还有以下缺陷,也是为啥会有$set
,$delete
的原因
1、属性的新加或者删除也无法监听;
2、数组元素的增加和删除也无法监听
reactive模块
看源码
1 | export function reactive(target: object) { |
稍微精简下
1 | function reactive(target) { |
基本上除了set map weakset 和weakmap,都是baseHandlers,下面重点关注一下,Proxy的语法 大家需要复习下es6
1 | export const readonlyHandlers: ProxyHandler<any> = { |
关于proxy
1 | let data = [1,2,3] |
比defineproperty优秀的 就是数组和对象都可以直接触发getter和setter, 但是数组会触发两次,因为获取push和修改length的时候也会触发
我们还可以用Reflect
1 | let data = [1,2,3] |
多次触发和深层嵌套问题,一会我们看vue3是怎么解决的
1 | let data = {name:{ title:'kkb'}} |
vue3深度检测
baseHander
1 |
|
返回值如果是object,就再走一次reactive,实现深度
vue3处理重复trigger
很简单,用的hasOwProperty, set肯定会出发多次,但是通知只出去一次, 比如数组修改length的时候,hasOwProperty是true, 那就不触发
1 | function set( |
手写vue3的reactive
刚才说的细节,我们手写一下
effect
computed
1 | // 用这个方法来模式视图更新 |
完整代码
1 |
|
测试代码
1 |
|
其他细节 track收集依赖,trigger触发更新
vue3其他模块细节
代码仓库中有个 packages 目录,里面主要是 Vue 3.0 的相关源码功能实现,具体内容如下所示。
compiler-core
平台无关的编译器,它既包含可扩展的基础功能,也包含所有平台无关的插件。暴露了 AST 和 baseCompile 相关的 API,它能把一个字符串变成一棵 AST
compiler-dom
针对浏览器的编译器。
runtime-core
与平台无关的运行时环境。支持实现的功能有虚拟 DOM 渲染器、Vue 组件和 Vue 的各种API, 可以用来自定义 renderer ,vue2中也有 ,入口代码看起来
runtime-dom
针对浏览器的 runtime。其功能包括处理原生 DOM API、DOM 事件和 DOM 属性等, 暴露了重要的render和createApp方法
1 | const { render, createApp } = createRenderer<Node, Element>({ |
runtime-test
一个专门为了测试而写的轻量级 runtime。比如对外暴露了renderToString方法,在此感慨和react越来越像了
server-renderer
用于 SSR,尚未实现。
shared
没有暴露任何 API,主要包含了一些平台无关的内部帮助方法。
vue
用于构建「完整」版本,引用了上面提到的 runtime 和 compiler目录。入口文件代码如下
1 |
|
所以想阅读源码,还是要看构建流程,这个和vue2也是一致的。