Vue3源码解析,打造自己的Vue3框架
以轻松的方式解构Vue3源码,掌握高阶编程思维
这不是一个高冷、不接地气的源码课!而是一个从开发者实际工作角度出发,结合 Vue 3 的设计机制,通过产出一个精简版 Vue 3 框架的方式,让大家可以站在 Vue 3 源码设计者的角度,俯视所有业务场景,彻底搞清楚每一行 Vue 代码背后,Vue 都做了什么!课程的核心设计原则:让更多的人,以更轻松的方式,学习Vue 3 源码!
适合人群
想要更深入的了解Vue的开发者
要在面试或者竞争中脱颖而出的开发者
技术储备
HTML5/CSS3/JS(ES6)
TypeScript
Vue基础
环境参数
node 14.17.3
npm 7.19.1
Vue 3.2.37
章节目录:
明确课程的核心:这是一个让《初级软件开发工程师都能够学会》同时可以让《高级软件工程师也能收获颇多,更进一步》的源码课
本章节主要需要介绍框架设计中的基本概念,因为对于很多开发者而言,平时工作中,更多的是针对应用进行开发,对框架本身的设计接触比较少,所以我们需要在一开始的时候,进行一个科普。
主要讲解Vue 3 源码如何进行 debugger、源码的各个模块是如何进行划分与配合工作的、Vue 3 的代码框架设计有什么独特之处。
从 vue 2 到 vue 3,从 Object.defineProperty 到 Proxy 。这样的升级带来了什么样的变化,Object.defineProperty 又存在哪些设计层的缺陷呢?本章统统告诉你
reactive 函数是响应性的核心函数之一。本章将讲解 reactive 函数是如何构建响应性的、vue 3对它的处理是什么、我们又应该如何实现它。
reactive 函数存在一定的不足。那么,本章将讲解ref 函数是如何弥补的这种不足的、为什么 ref 必须要通过 .value 获取数据、为什么 ref 解构之后不会失去响应性、Ref 和 reactive 之间又存在什么关系。
响应性的变化总是及时的?那么是否存在惰性的响应性呢? Vue 中所谓的调度系统又是什么意思?Watch 和 computed 在源码层存在什么样的区别?它们有和 reactive 存在什么差异呢?
在构建运行时之前,我们需要了解的基础概念,比如:DOM 树和虚拟 DOM 树的关系,render 函数和 h 函数的关系,运行时的核心设计原则…
h 函数作为运行时的核心函数,我们应该如何进行构建。Vnode 中对 Element、component、Text、Comment、Fragment 又如何进行划分?
渲染器是运行时最核心的内容,针对不同的 Vnode 渲染器如何进行处理。在浏览器端和 SSR 端这些不同的宿主环境下, 节点的挂载又是如何进行呢?
组件是 vue 中非常重要的一块内容,值得我们花费一个单独的模块进行讲解。对组件而言,他不光包含了 render 的渲染函数,它还额外包含了 data 响应性数据、生命周期钩子等内容,针对于这么复杂的场景,vue 是如何进行设计的?我们又应该如何处理呢?这些都会在本章进行讲解…
diff 算法是 渲染器的核心算法,它会在什么场景下进行执行?整个的 diff 逻辑是如何运转的?最长递增子序列指的又是什么?学完本章,以上内容再也难不到你。
编译器是 vue 中最后一个大模块,里面涉及到了一些冷僻的概念和复杂的逻辑。所以想要学习编辑器,那么我们需要先站在足够高的“地方” 俯视整个编辑器逻辑,掌握它的核心执行规律。
AST 抽象语法树、JavaScript AST、render 函数生成。在我们了解了整个编译的大步骤之后,接下来我们就需要深入各个步骤,来掌握编译器的执行过程了。
仅仅掌握一个基础的编译器,可能并不能满足大家的胃口。所以在本章中,我们将深入编译器逻辑,从响应性处理、多层渲染、指令这三个方面入手,帮助大家深入编译器逻辑。
三大模块的合并策略,助你得到一个属于自己的 vue 3 框架
本章是课程的最后一节了,到此课程就完结了,武功秘籍已经传授给大家了,后面大家就要自己闯荡江湖了。
Copyright © 2023-2024 - All rights reserved备案号: 黔ICP备15010373号-7
若您需要使用非免费的软件或服务,请购买正版授权并合法使用。本站资源仅供学习研究。若发布的内容若侵犯到您的权益,请联系站长我们将及时处理。