vue.js设计与实现(待续)

第一篇 框架设计概览
第 1 章 权衡的艺术
1.1.什么是声明式,什么是命令式

命令式:
$('#app').text('hello world').on('click', () => { alert('ok') })

1.2 性能与可维护性的权衡

注意:

  1. 声明式代码的性能不优于命令式代码的性能
  2. 命令式 更加关注过程 ,而声明式 更加关注结果
  3. vue之所以用声明式,因为声明式代码的可维护性更强
1.3 虚拟 DOM 的性能到底如何
  • 虚拟 DOM是为了最小化找出差异 这一步的性能消耗而出现的
1.4 运行时和编译时
  1. 框架:纯运行时的(不直观)、运行时 +编译时的、纯编译时
  2. Vue.js 3 保持了运行时 + 编译时的架构
第 2 章 框架设计的核心要素

模块打包工具:rollup.js 和 webpack

2.1 提升用户的开发体验
2.2 控制框架代码的体积
2.3 框架要做到良好的 Tree-Shaking
  • Tree-Shaking 指的就是消除那些永远不会被执行的代码,也就是排除 dead code,现在无论是 rollup.js 还是 webpack,都支持Tree-Shaking
  • 想要实现 Tree-Shaking,必须满足一个条件,即模块必须是ESM(ES Module)
  • 注意注释代码 /#PURE/,其作用就是告诉 rollup.js,对于函数的调用不会产生副作用,你可以放心地对其进行TreeShaking(该注释也不是只有 rollup.js 才能识别,webpack 以及压缩工具(如 terser)都能识别它)
2.4 框架应该输出怎样的构建产物
  • 如何用Rollup.js安装打包
  1. 初始化项目(一路回车即可,默认配置)

npm init -y

  1. 安装到 devDependencies(开发依赖)

npm install rollup --save-dev

  1. 编写测试代码
javascript 复制代码
//src/utils.js(工具模块,被入口文件依赖)
export const add = (a, b) => a + b;
export const minus = (a, b) => a - b; // 未被使用,会被 Tree-Shaking 剔除

// src/main.js(入口文件,Rollup 从这里开始打包)
import { add } from './utils.js';
console.log('2+3=', add(2, 3));
  1. 打包成 IIFE 格式(浏览器全局使用)

npx rollup src/main.js -o dist/bundle.iife.js -f iife --name "MyUtils"

  1. 输出文件 dist/bundle.iife.js 可直接用 <script> 引入浏览器
  2. 在 Node.js 环境中运行时需打包成cjs格式文件
2.5 特性开关
  • 示例:为了兼容 Vue.js 2,在 Vue.js 3 中仍然可以使用选项 API 的方式编写代码。但是如果明确知道自己不会使用选项 API,用户就可以使用 VUE_OPTIONS_API 开关来关闭该特性,这样在打包的时候Vue.js 的这部分代码就不会包含在最终的资源中,从而减小资源体积
2.6 错误处理
  • 统一方法进行错误处理
2.7 良好的 TypeScript 类型支持

使用 TS 编写框架和框架对 TS 类型支持友好是两件完全不同的事

第 3 章 Vue.js 3 的设计思路
3.1 声明式地描述 UI

一个组件要渲染的内容是通过渲染函数来描述的,render 函数,Vue.js 会根据组件的 render 函数的返回值拿到虚拟 DOM,然后就可以把组件的内容渲染出来

3.2 初识渲染器

虚拟DOM 其实:用来描述真实 DOM 的普通 JavaScript 对象

render函数

3.3 组件的本质
  1. 组件是什么?
  2. 组件和虚拟 DOM 有什么关系?
  3. 渲染器如何渲染组件
3.4 模板的工作原理

编译器:将模板编译为渲染函数

3.5 Vue.js 是各个模块组成的有机整体

第二篇 响应系统

第 4 章 响应系统的作用与实现
第 5 章 非原始值的响应式方案
第 6 章 原始值的响应式方
相关推荐
来杯@Java18 小时前
学生选课管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·maven·mybatis
医疗信息化王工1 天前
医院自律端系统——预警处置模块全栈实战(ASP.NET Core + Vue3 + Quartz 定时调度)
mysql·postgresql·vue·asp.net core·quartz
大大杰哥1 天前
Vue2学习(1)--了解基本方法与概念
javascript·学习·vue
Agatha方艺璇2 天前
前端开发技术复习笔记
vue·bootstrap·css3·html5·web
小葛要努力2 天前
创建vue2项目
程序人生·vue
七仔啊2 天前
基于海康门禁的人员计数系统
vue
步十人3 天前
【Vue3】前置知识简单概述(包括ES6核心语法,模块化ESM以及npm基础)
arcgis·npm·vue·es6
有梦想的程序星空4 天前
【环境配置】Vue3项目离线化本地部署echarts全攻略
前端·javascript·vue·echarts
向日的葵0064 天前
vue路由(二)
前端·javascript·vue.js·vue
小妖6665 天前
Hydration completed but contains mismatches
javascript·vue·vuepress