Skip to content

Latest commit

 

History

History
65 lines (54 loc) · 2.02 KB

readme.md

File metadata and controls

65 lines (54 loc) · 2.02 KB

简介

本项目从零逐步重写一个涵盖 Vue3 核心逻辑的的微模型,遵循真实的 Vue3 代码结构,但不会包含所有的优化以及非必要的功能,主要包括三大核心模块: reactivity(响应系统)、runtime(渲染器)、compiler(编译器),以此来深入学习理解 Vue3 源码。

项目主要参考《Vue.js 设计与实现》与 mini-vue

特点

  • 剔除处理边缘逻辑代码, 注重核心代码的实现
  • 保持和 vue3 源码一致的命名, 目的是为了更加容易去阅读源码

实现的功能

reactivity

  • 项目初始化:集成 jest 测试环境
  • 实现 effect、reactive、依赖收集、依赖触发
  • 实现 effect 返回 runner
  • 实现 effect 的 scheduler (调度器)
  • 实现 stop
  • 实现 readonly
  • 重构 reative 和 readonly
  • 实现 isReactive 和 isReadonly
  • 优化 stop
  • 实现 reactive 和 readonly(嵌套对象转换)
  • 实现 shallowReadonly
  • 实现 isProxy
  • 实现 ref
  • 实现 isRef 和 unRef
  • 实现 computed

runtime

  • 实现 初始化 component 和 element 的主流程
  • 使用 rollup(打包库)
  • 实现 组件代理对象(setup 中 this 的指向)
  • 实现 shapeFlags(描述虚拟节点的类型)
  • 实现 事件绑定
  • 实现 组件 props 的功能
  • 实现 组件 emit 的功能
  • 实现 组件 slots 的功能
  • 实现 Fragment 和 Text 类型节点
  • 实现 getCurrentInstance
  • 实现 provide/inject
  • 实现 自定义渲染器 custom renderer
  • 实现 element 更新(基于 children 和 props)
  • 实现 简单 Diff 算法
  • 实现 双端 Diff 算法
  • 实现 快速 Diff 算法
  • 实现 组件更新
  • 实现 视图异步更新和 nextTick

compiler

  • 实现 编译模块 大致流程
  • 实现 解析插值表达式
  • 实现 解析 Element
  • 实现 解析 Text
  • 探究 parse 实现原理(有限状态机)
  • 实现 transform
  • 实现 codegen string
  • 实现 codegen text
  • 实现 codegen element
  • 实现 codegen 三种类型
  • 实现 compiler 2 render 2 vnode 2 dom