从零开始搭建简易Vue框架——(二)vue-mini核心模块介绍

新增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 源码中的一个核心模块,主要负责实现模板编译的相关功能。具体作用包括:

  1. 将模板编译成渲染函数:compiler-core 模块提供了将模板编译成渲染函数的功能,这样 Vue.js 在运行时可以直接使用渲染函数来渲染组件。
  2. 提供编译相关的工具函数:compiler-core 模块中包含了一些编译相关的工具函数,用于处理模板中的指令、表达式等内容,以便生成可执行的渲染函数。
  3. 定义编译过程中的 AST 节点类型:compiler-core 模块定义了编译过程中使用的 AST(抽象语法树)节点类型,用于表示模板中的各种语法结构。
  4. 提供编译器的核心逻辑:compiler-core 模块中包含了编译器的核心逻辑,负责将模板转换成 AST,再进一步转换成渲染函数。

总的来说,compiler-core 模块在 Vue.js 中起着将模板编译成可执行代码的关键作用,是 Vue.js 实现模板编译功能的核心部分。

runtime-dom

runtime-dom 模块是 Vue.js 源码中的一个核心模块,主要负责处理与浏览器 DOM 相关的操作。具体作用包括:

  1. 创建虚拟 DOM:runtime-dom 模块负责创建虚拟 DOM 对象,用于表示组件的结构和状态,以便在页面上进行高效的 DOM 操作。
  2. 将虚拟 DOM 渲染到真实 DOM:runtime-dom 模块负责将虚拟 DOM 渲染到真实的浏览器 DOM 中,实现组件在页面上的显示和交互。
  3. 处理事件绑定和事件监听:runtime-dom 模块提供了事件绑定和事件监听的功能,使得组件能够响应用户的交互操作。
  4. 处理属性、样式和类名的更新:runtime-dom 模块负责处理组件属性、样式和类名等内容的更新,保持页面内容与组件状态的同步。
  5. 提供一些实用的 DOM 操作方法:runtime-dom 模块中还包含了一些实用的 DOM 操作方法,如创建元素、插入元素、更新元素等,方便开发者进行 DOM 操作。

总的来说,runtime-dom 模块在 Vue.js 中起着将虚拟 DOM渲染到真实 DOM 的关键作用,是 Vue.js 实现组件渲染和交互的核心部分。

shared

shared 模块是 Vue.js 源码中的一个核心模块,主要用于定义一些在整个 Vue.js 代码库中共享使用的工具函数、常量和数据结构。具体作用包括:

  1. 定义常量:shared 模块中定义了一些常量,如 Vue.js 的版本号、错误信息等,这些常量在整个代码库中都可以被访问和使用。
  2. 定义工具函数:shared 模块包含了一些通用的工具函数,如类型判断、对象操作、数组操作等,这些工具函数可以被其他模块引用和复用。
  3. 定义数据结构:shared 模块中定义了一些数据结构,如响应式数据、观察者对象等,这些数据结构在整个 Vue.js 中都有广泛的应用。
  4. 提供跨模块共享的功能:shared 模块中的内容可以被其他模块引用和共享,避免了重复定义和提高了代码的复用性。

总的来说,shared 模块在 Vue.js 中起着定义共享工具函数、常量和数据结构的作用,为整个代码库提供了一些通用的功能和数据结构,方便各个模块之间的交互和复用。

总结

总而言之,庞大繁复的Vue框架就是由这三大模块相互配合从而完成了场景多如繁星的业务逻辑。后续的文章我会详细介绍各大模块的实现。

相关推荐
小小小小宇1 小时前
ESLint 插件笔记
前端
纪伊路上盛名在1 小时前
jupyter内核崩溃
前端·数据库·jupyter·生物信息·基因组·k-mer
Net蚂蚁代码3 小时前
Angular入门的环境准备步骤工作
前端·javascript·angular.js
小阮的学习笔记4 小时前
electron实现加载页(启动页)
vue.js·electron
小着5 小时前
vue项目页面最底部出现乱码
前端·javascript·vue.js·前端框架
lichenyang4538 小时前
React ajax中的跨域以及代理服务器
前端·react.js·ajax
呆呆的小草8 小时前
Cesium距离测量、角度测量、面积测量
开发语言·前端·javascript
一 乐9 小时前
民宿|基于java的民宿推荐系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·源码
testleaf9 小时前
前端面经整理【1】
前端·面试
BillKu9 小时前
Vue3 + TypeScript + Element Plus 表格行按钮不触发 row-click 事件、不触发勾选行,只执行按钮的 click 事件
vue.js·elementui·typescript