新增Vue模块
上文我们已经配置好rollup打包文件,接下来我们要做的是构建Vue模块作为我们的核心展示模块,主要包含对我们核心模块的example和打包好的cjs和esm-bundler文件。
新建packages
新建包文件夹,具体文件目录如下:
进入到 vue 文件夹下,初始化js项目,完成后的目录如下:
Vue核心模块包
下面我们需要将核心模块作为包管理引入到vue文件夹下的package.json中。其中主要分为三大模块compiler-core、runtime-dom 以及 shared。
compiler-core
compiler-core
模块是 Vue.js 源码中的一个核心模块,主要负责实现模板编译的相关功能。具体作用包括:
- 将模板编译成渲染函数:
compiler-core
模块提供了将模板编译成渲染函数的功能,这样 Vue.js 在运行时可以直接使用渲染函数来渲染组件。 - 提供编译相关的工具函数:
compiler-core
模块中包含了一些编译相关的工具函数,用于处理模板中的指令、表达式等内容,以便生成可执行的渲染函数。 - 定义编译过程中的 AST 节点类型:
compiler-core
模块定义了编译过程中使用的 AST(抽象语法树)节点类型,用于表示模板中的各种语法结构。 - 提供编译器的核心逻辑:
compiler-core
模块中包含了编译器的核心逻辑,负责将模板转换成 AST,再进一步转换成渲染函数。
总的来说,compiler-core
模块在 Vue.js 中起着将模板编译成可执行代码的关键作用,是 Vue.js 实现模板编译功能的核心部分。
runtime-dom
runtime-dom
模块是 Vue.js 源码中的一个核心模块,主要负责处理与浏览器 DOM 相关的操作。具体作用包括:
- 创建虚拟 DOM:
runtime-dom
模块负责创建虚拟 DOM 对象,用于表示组件的结构和状态,以便在页面上进行高效的 DOM 操作。 - 将虚拟 DOM 渲染到真实 DOM:
runtime-dom
模块负责将虚拟 DOM 渲染到真实的浏览器 DOM 中,实现组件在页面上的显示和交互。 - 处理事件绑定和事件监听:
runtime-dom
模块提供了事件绑定和事件监听的功能,使得组件能够响应用户的交互操作。 - 处理属性、样式和类名的更新:
runtime-dom
模块负责处理组件属性、样式和类名等内容的更新,保持页面内容与组件状态的同步。 - 提供一些实用的 DOM 操作方法:
runtime-dom
模块中还包含了一些实用的 DOM 操作方法,如创建元素、插入元素、更新元素等,方便开发者进行 DOM 操作。
总的来说,runtime-dom
模块在 Vue.js 中起着将虚拟 DOM渲染到真实 DOM 的关键作用,是 Vue.js 实现组件渲染和交互的核心部分。
shared
shared
模块是 Vue.js 源码中的一个核心模块,主要用于定义一些在整个 Vue.js 代码库中共享使用的工具函数、常量和数据结构。具体作用包括:
- 定义常量:
shared
模块中定义了一些常量,如 Vue.js 的版本号、错误信息等,这些常量在整个代码库中都可以被访问和使用。 - 定义工具函数:
shared
模块包含了一些通用的工具函数,如类型判断、对象操作、数组操作等,这些工具函数可以被其他模块引用和复用。 - 定义数据结构:
shared
模块中定义了一些数据结构,如响应式数据、观察者对象等,这些数据结构在整个 Vue.js 中都有广泛的应用。 - 提供跨模块共享的功能:
shared
模块中的内容可以被其他模块引用和共享,避免了重复定义和提高了代码的复用性。
总的来说,shared
模块在 Vue.js 中起着定义共享工具函数、常量和数据结构的作用,为整个代码库提供了一些通用的功能和数据结构,方便各个模块之间的交互和复用。
总结
总而言之,庞大繁复的Vue框架就是由这三大模块相互配合从而完成了场景多如繁星的业务逻辑。后续的文章我会详细介绍各大模块的实现。