my-mini-vue icon indicating copy to clipboard operation
my-mini-vue copied to clipboard

vue3的一些核心逻辑,自己实现的vue3简易版(核心逻辑)框架。

mini-vue

实现最简 vue3 模型,用于深入学习 vue3
这个是配套的笔记 搭配起来食用更佳哟

Why

当我们需要深入学习 vue3 时,我们就需要看源码来学习,但是像这种工业级别的库,源码中有很多逻辑是用于处理边缘情况或者是兼容处理逻辑,是不利于我们学习的。

我们应该关注于核心逻辑,而这个库的目的就是把 vue3 源码中最核心的逻辑剥离出来,只留下核心逻辑,以供大家学习。

How

基于 vue3 的功能点,一点一点的拆分出来。

代码命名会保持和源码中的一致,方便大家通过命名去源码中查找逻辑。

Tasking

runtime-core

  • [x] 支持组件类型
  • [x] 支持 element 类型
  • [x] 初始化 props
  • [x] setup 可获取 props 和 context
  • [x] 支持 component emit
  • [x] 支持 proxy
  • [x] 可以在 render 函数中获取 setup 返回的对象
  • [x] nextTick 的实现
  • [x] 支持 getCurrentInstance
  • [x] 支持 provide/inject
  • [x] 支持最基础的 slots
  • [x] 支持 Text 类型节点
  • [x] 支持 $el api

reactivity

目标是用自己的 reactivity 支持现有的 demo 运行

  • [x] reactive 的实现
  • [x] ref 的实现
  • [x] readonly 的实现
  • [x] computed 的实现
  • [x] track 依赖收集
  • [x] trigger 触发依赖
  • [x] 支持 isReactive
  • [x] 支持嵌套 reactive
  • [x] 支持 toRaw
  • [x] 支持 effect.scheduler
  • [x] 支持 effect.stop
  • [x] 支持 isReadonly
  • [x] 支持 isProxy
  • [x] 支持 shallowReadonly
  • [x] 支持 proxyRefs

runtime-dom

  • [x] 支持 custom renderer

build

yarn build

example

通过 server 的方式打开 example/* 下的 index.html 即可

推荐使用 Live Server

初始化

流程图

初始化流程图

关键函数调用图

关键函数调用图2

可以基于函数名快速搜索到源码内容

update

流程图

image

关键函数调用图

image

可以基于函数名快速搜索到源码内容