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 章 原始值的响应式方
相关推荐
vivo互联网技术18 小时前
浅谈 AI 搜索前端打字机效果的实现方案演进
前端·vue·dom
harrain5 天前
vue2开发环境搭建指南
vue
by__csdn5 天前
Electron+Vite:实现electron + vue3 + ts + pinia + vite高效跨平台开发指南
前端·javascript·vue.js·typescript·electron·node.js·vue
人工智能训练6 天前
前端框架选型破局指南:Vue、React、Next.js 从差异到落地全解析
运维·javascript·人工智能·前端框架·vue·react·next.js
李纲明7 天前
WordPress外贸成品网站的免费获取渠道
vue·php
加洛斯8 天前
前端小知识002:ref 与 reactive 详解
前端·vue
计算机毕设vx_bysj68698 天前
计算机毕业设计必看必学~Springboot教学进度管理系统,原创定制程序、单片机、java、PHP、Python、小程序、文案全套、毕设成品等!
java·spring boot·vue·课程设计·管理系统
小贺要学前端9 天前
【无标题】
前端·javascript·vue·技术趋势
IT教程资源C9 天前
(N_141)基于springboot,vue网上拍卖平台
mysql·vue·前后端分离·拍卖系统·springboot拍卖
IT教程资源C9 天前
(N_144)基于微信小程序在线订餐系统
mysql·vue·uniapp·前后端分离·订餐小程序·springboot订餐