Vue.js设计与实现(霍春阳)

Vue.js设计与实现 (霍春阳)

        电子版获取链接:Vue.js设计与实现(霍春阳)

read-normal-img

编辑推荐

适读人群 :1.对Vue.js 2/3具有上手经验,且希望进一步理解Vue.js框架设计原理的开发人员; 2.没有使用过Vue.js,但对Vue.js框架设计感兴趣的前端开发人员。

1.Vue.js 官方团队成员霍春阳倾力打造;

2.基于 Vue.js 3 深入解析 Vue.js 设计细节;

3.Vue.js 作者尤雨溪作序推荐;

4.本书提供源代码下载;

5.业界大咖联袂推荐。

内容简介

本书基于Vue.js 3,从规范出发,以源码为基础,并结合大量直观的配图,循序渐进地讲解Vue.js中各个功能模块的实现,细致剖析框架设计原理。全书共18章,分为六篇,主要内容包括:框架设计概览、响应系统、渲染器、组件化、编译器和服务端渲染等。通过阅读本书,对Vue.js 2/3具有上手经验的开发人员能够进一步理解Vue.js框架的实现细节,没有Vue.js使用经验但对框架设计感兴趣的前端开发人员,能够快速掌握Vue.js的设计原理。

作者简介

霍春阳(HcySunYang)

Vue.js官方团队成员,专注于Web研发领域,是Vue.js 3的核心贡献者之一,Vue.js文档生成工具Vuese的作者,技术社区活跃者,曾撰写大量颇受好评的技术博客。

精彩书评

这本书对Vue.js 3技术细节的分析非常可靠,对于需要深入理解Vue.js 3的用户会有很大的帮助。

--尤雨溪,Vue.js作者

听到春阳在筹备这本书时,我就期待不已。以他对Vue.js的贡献与理解程度,编写这本书真是再适合不过了!春阳从框架设计者的角度巧妙地切入,自底层由浅入深地阐述Vue.js的设计思想。身为Vue.js多年使用者的我,也被书中丰富的细节所震撼,读后受益匪浅。若想更好地理解与使用Vue.js,我极力推荐本书。

--Anthony Fu,Vue.js和Vite核心团队成员

春阳是Vue.js团队中对框架源码钻研最深的人之一。

这本《Vue.js设计与实现》并非简单的源码解析之作,反而深入浅出,既从设计理念的角度阐述了Vue.js的技术选择,也讲解了更为通用的算法知识和JavaScript语言规范细节。这本书不仅能帮助前端新手理解前端框架功能,而且为资深开发者阅读源码提供助力,还能对广大的前端技术爱好者有所启发,非常值得一读。

--蒋豪群,Vue.js和Vite核心团队成员

当前,在开发前端应用程序时,Vue.js已经是**技术之一了。使用Vue.js的开发者数量庞大,其中很多人尝试阅读源码,以期了解更多细节。

本书从核心团队开发者的角度,详细解析了从无到有开发Vue.js的技术细节,以及背后的工程权衡,其细节之丰富,远超第三方源码解读。想要深入框架细节的业务开发者以及各类组件、框架和平台开发者,都可以从本书中受益。此外,作者的技术实力和写作态度,也保证了本书的品质。

--(飞叔)徐飞

数据驱动的前端框架已成为现代前端研发的标准配置。Vue.js作为其中脱颖而出的主流选择之一,有许多值得前端开发者学习、借鉴的思想和实践。作为Vue.js 3的核心贡献者,春阳对Vue.js的各个方面都有很深入的理解。这本书为读者详细展示了Vue.js的设计原理与实践细节,以及框架设计背后的权衡艺术,是一本不容错过的好书。我相信所有对Vue.js、框架设计感兴趣的开发者读完这本书后,都能有更进一步的理解。

--顾轶灵,百度资深研发工程师,Vue.js官方团队成员

我特别喜欢《Vue.js设计与实现》这本书,它会为你打开一扇门,开辟一种新的思维,建立对Vue.js全新的认知。

--刘博文(玖五),《深入浅出Vue.js》作者,阿里巴巴大淘宝前端技术专家

目录

前言

第 1章 权衡的艺术 2

1.1 命令式和声明式 2

1.2 性能与可维护性的权衡 3

1.3 虚拟DOM的性能到底如何 4

1.4 运行时和编译时 8

1.5 总结 11

第 2章 框架设计的核心要素 12

2.1 提升用户的开发体验 12

2.2 控制框架代码的体积 14

2.3 框架要做到良好的Tree-Shaking 15

2.4 框架应该输出怎样的构建产物 17

2.5 特性开关 19

2.6 错误处理 21

2.7 良好的TypeScript类型支持 23

2.8 总结 25

第3章 Vue.js 3的设计思路 27

3.1 声明式地描述UI 27

3.2 初识渲染器 29

3.3 组件的本质 32

3.4 模板的工作原理 34

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

3.6 总结 37

第4章 响应系统的作用与实现 40

4.1 响应式数据与副作用函数 40

4.2 响应式数据的基本实现 41

4.3 设计一个完善的响应系统 43

4.4 分支切换与cleanup 50

4.5 嵌套的effect与effect栈 55

4.6 避免无限递归循环 59

4.7 调度执行 60

4.8 计算属性computed与lazy 64

4.9 watch的实现原理 71

4.10 立即执行的watch与回调执行时机 75

4.11 过期的副作用 77

4.12 总结 82

第5章 非原始值的响应式方案 84

5.1 理解Proxy和Reflect 84

5.2 JavaScript对象及Proxy的工作原理 88

5.3 如何代理Object 92

5.4 合理地触发响应 102

5.5 浅响应与深响应 108

5.6 只读和浅只读 110

5.7 代理数组 113

5.7.1 数组的索引与 length 114

5.7.2 遍历数组 119

5.7.3 数组的查找方法 124

5.7.4 隐式修改数组长度的原型方法 129

5.8 代理Set和Map 132

5.8.1 如何代理Set和Map 133

5.8.2 建立响应联系 137

5.8.3 避免污染原始数据 140

5.8.4 处理forEach 143

5.8.5 迭代器方法 147

5.8.6 values与keys方法 152

5.9 总结 155

第6章 原始值的响应式方案 158

6.1 引入ref的概念 158

6.2 响应丢失问题 160

6.3 自动脱ref 164

6.4 总结 166

第7章 渲染器的设计 170

7.1 渲染器与响应系统的结合 170

7.2 渲染器的基本概念 172

7.3 自定义渲染器 175

7.4 总结 179

第8章 挂载与更新 180

8.1 挂载子节点和元素的属性 180

8.2 HTML Attributes与DOM Properties 182

8.3 正确地设置元素属性 184

8.4 class的处理 189

8.5 卸载操作 192

8.6 区分vnode的类型 195

8.7 事件的处理 196

8.8 事件冒泡与更新时机问题 201

8.9 更新子节点 204

8.10 文本节点和注释节点 209

8.11 Fragment 212

8.12 总结 215

第9章 简单Diff算法 218

9.1 减少DOM操作的性能开销 218

9.2 DOM复用与key的作用 221

9.3 找到需要移动的元素 225

9.4 如何移动元素 228

9.5 添加新元素 233

9.6 移除不存在的元素 238

9.7 总结 241

第 10章 双端Diff算法 242

10.1 双端比较的原理 242

10.2 双端比较的优势 252

10.3 非理想状况的处理方式 255

10.4 添加新元素 263

10.5 移除不存在的元素 268

10.6 总结 270

第 11章 快速Diff算法 271

11.1 相同的前置元素和后置元素 271

11.2 判断是否需要进行DOM移动操作 279

11.3 如何移动元素 288

11.4 总结 296

第 12章 组件的实现原理 298

12.1 渲染组件 298

12.2 组件状态与自更新 301

12.3 组件实例与组件的生命周期 304

12.4 props与组件的被动更新 306

12.5 setup函数的作用与实现 311

12.6 组件事件与emit的实现 314

12.7 插槽的工作原理与实现 316

12.8 注册生命周期 318

12.9 总结 320

第 13章 异步组件与函数式组件 322

13.1 异步组件要解决的问题 322

13.2 异步组件的实现原理 324

13.2.1 封装defineAsyncComponent函数 324

13.2.2 超时与Error组件 325

13.2.3 延迟与Loading组件 328

13.2.4 重试机制 331

13.3 函数式组件 333

13.4 总结 335

第 14章 内建组件和模块 337

14.1 KeepAlive组件的实现原理 337

14.1.1 组件的激活与失活 337

14.1.2 include和exclude 342

14.1.3 缓存管理 343

14.2 Teleport组件的实现原理 346

14.2.1 Teleport组件要解决的问题 346

14.2.2 实现Teleport组件 347

14.3 Transition组件的实现原理 350

14.3.1 原生DOM的过渡 351

14.3.2 实现Transition组件 356

14.4 总结 360

第 15章 编译器核心技术概览 364

15.1 模板DSL的编译器 364

15.2 parser的实现原理与状态机 368

15.3 构造AST 374

15.4 AST的转换与插件化架构 383

15.4.1 节点的访问 383

15.4.2 转换上下文与节点操作 387

15.4.3 进入与退出 392

15.5 将模板AST转为JavaScript AST 396

15.6 代码生成 402

15.7 总结 407

第 16章 解析器 409

16.1 文本模式及其对解析器的影响 409

16.2 递归下降算法构造模板AST 413

16.3 状态机的开启与停止 419

16.4 解析标签节点 426

16.5 解析属性 430

16.6 解析文本与解码HTML实体 436

16.6.1 解析文本 436

16.6.2 解码命名字符引用 438

16.6.3 解码数字字符引用 445

16.7 解析插值与注释 449

16.8 总结 451

第 17章 编译优化 453

17.1 动态节点收集与补丁标志 453

17.1.1 传统Diff算法的问题 453

17.1.2 Block与PatchFlags 454

17.1.3 收集动态节点 457

17.1.4 渲染器的运行时支持 459

17.2 Block树 461

17.2.1 带有v-if指令的节点 462

17.2.2 带有v-for指令的节点 464

17.2.3 Fragment的稳定性 465

17.3 静态提升 466

17.4 预字符串化 468

17.5 缓存内联事件处理函数 469

17.6 v-once 470

17.7 总结 471

第 18章 同构渲染 474

18.1 CSR、SSR以及同构渲染 474

18.2 将虚拟DOM渲染为HTML字符串 478

18.3 将组件渲染为HTML字符串 484

18.4 客户端激活的原理 489

18.5 编写同构的代码 494

18.5.1 组件的生命周期 494

18.5.2 使用跨平台的API 496

18.5.3 只在某一端引入模块 496

18.5.4 避免交叉请求引起的状态污染 497

18.5.5 组件 498

18.6 总结 499

本文禁止转载或摘编

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/369345.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Loki使用指南

转载至我的博客 https://www.infrastack.cn ,公众号:架构成长指南 与其他日志系统相比, Loki 的使用方式是有一定差异性的,需要用不同的思维方式。本文分享一下这些差异以及我们应该如何使用 作为 Loki 用户或操作人员&#xff0…

Leetcode—37. 解数独【困难】

2024每日刷题&#xff08;111&#xff09; Leetcode—37. 解数独 实现代码 class Solution { public:bool isValid(vector<vector<char>>& board, int row, int col, char c) {for(int i 0; i < 9; i) {if(board[row][i] c || board[i][col] c || boar…

最新GPT4.0使用教程,AI绘画,GPT语音对话使用,DALL-E3文生图

一、前言 ChatGPT3.5、GPT4.0、GPT语音对话、Midjourney绘画&#xff0c;文档对话总结DALL-E3文生图&#xff0c;相信对大家应该不感到陌生吧&#xff1f;简单来说&#xff0c;GPT-4技术比之前的GPT-3.5相对来说更加智能&#xff0c;会根据用户的要求生成多种内容甚至也可以和…

界面控件DevExpress ASP.NET Spreadsheet组件 - 轻松集成电子表格功能!(一)

DevExpress ASP. NET Spreadsheet组件允许您轻松地将电子表格功能合并到任意ASP. NET应用程序&#xff0c;它可以加载、转换和保存工作簿到XLS-XLSx二进制文件格式&#xff0c;还可以导出和导入XLSX、CSV和TXT文件。 P.S&#xff1a;DevExpress ASP.NET Web Forms Controls拥有…

STM32--SPI通信协议(1)SPI基础知识总结

前言 I2C (Inter-Integrated Circuit)和SPI (Serial Peripheral Interface)是两种常见的串行通信协议&#xff0c;用于连接集成电路芯片之间的通信&#xff0c;选择I2C或SPI取决于具体的应用需求。如果需要较高的传输速度和简单的接口&#xff0c;可以选择SPI。如果需要连接多…

开关电源学习之Buck电路

一、引言 观察上方的电路&#xff0c;当开关闭合到A点时&#xff0c;电流流过电感线圈&#xff0c;形成阻碍电流流过的磁场&#xff0c;即产生相反的电动势&#xff1b;电感L被充磁&#xff0c;流经电感的电流线性增加&#xff0c;在电感未饱和前&#xff0c;电流线性增加&…

零基础Vue框架上手;git,node,yarn安装

项目搭建环境&#xff1a; git安装&#xff1a;Git - 安装 Git (git-scm.com)&#xff08;官网&#xff09; 下载路径&#xff1a;Git - Downloading Package (git-scm.com)&#xff1b;根据自己电脑下载相对应的安装包 ​ 点next ​ 点next&#xff0c;点到最后安装就行。…

航母编队反无人机蜂群作战能力需求分析

源自&#xff1a;指挥控制与仿真 作者&#xff1a;樊辉锦、巫银花、毕月、苏泽亚 “人工智能技术与咨询” 发布 声明:公众号转载的文章及图片出于非商业性的教育和科研目的供大家参考和探讨&#xff0c;并不意味着支持其观点或证实其内容的真实性。版权归原作者所有&#xf…

【DBF格式转换器.exe】

一、概要 DBF文件是一种数据库文件格式&#xff0c;通常用于存储表格数据。这种文件格式曾经被广泛使用&#xff0c;尤其是在一些较旧的数据库系统中。然而&#xff0c;随着时间的推移&#xff0c;其他更现代的文件格式&#xff0c;如XLS&#xff08;Excel&#xff09;、CSV、D…

红日靶场1搭建渗透

环境搭建 下载好镜像文件并解压&#xff0c;启动vmware 这里我用自己的win7 sp1虚拟机作为攻击机&#xff0c;设置为双网卡NAT&#xff0c;vm2 其中用ipconfig查看攻击机ip地址 设置win7 x64为双网卡&#xff0c;vm1&#xff0c;vm2 设置win08单网卡vm1&#xff0c;win2k3为单…

Leetcode—32. 最长有效括号【困难】(动态规划及ranges::max()使用)

2024每日刷题&#xff08;110&#xff09; Leetcode—32. 最长有效括号 栈实现代码 class Solution { public:int longestValidParentheses(string s) {stack<int> st;st.push(-1);int n s.size();int maxn 0;for(int i 0; i < n; i) {if(s[i] () {st.push(i);}…

《幻兽帕鲁》好玩吗?幻兽帕鲁能在Mac上运行吗?

最近一款叫做《幻兽帕鲁》的新游戏走红&#xff0c;成为了Steam游戏平台上&#xff0c;连续3周的销量冠军&#xff0c;有不少Mac电脑用户&#xff0c;利用Crossover成功玩上了《幻兽帕鲁》&#xff0c;其实Crossover已经支持很多3A游戏&#xff0c;包括《赛博朋克2077》《博德之…

XUbuntu22.04之两款实用画笔工具(二百一十)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a;多媒…

开发智能化企业培训平台:教育系统源码的创新方法

在传统的企业培训模式中&#xff0c;往往面临着效率低下、内容过时以及难以个性化的问题。为了解决这些挑战&#xff0c;采用智能化技术成为了企业培训领域的热门趋势。通过开发智能化企业培训平台&#xff0c;可以提高培训效果、降低成本&#xff0c;并更好地满足员工多样化的…

【漏洞复现】MDVR数字视频录像机认证绕过漏洞

Nx01 产品简介 MDVR&#xff08;Mobile Digital Video Recorders&#xff09;硬盘录像机是一种使用先进的视音频编解码技术将车内外的视频进行数模转换&#xff0c;进行压缩存储的设备。 Nx02 漏洞描述 阿根廷研究员发现&#xff0c;通过使用“Cookie&#xff1a; uid admin”…

红队渗透靶机:TIKI: 1

目录 信息收集 1、arp 2、nmap 3、nikto 4、whatweb 目录探测 1、dirsearch 2、gobuster WEB web信息收集 searchsploit cms信息收集 ssh登录 提权 信息收集 1、arp ┌──(root㉿ru)-[~/kali] └─# arp-scan -l Interface: eth0, type: EN10MB, MAC: 00:0c:2…

基于Springboot开发的物品捎带系统[附源码]

基于Springboot开发的物品捎带系统[附源码] &#x1f345; 作者主页 央顺技术团队 &#x1f345; 欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; &#x1f345; 文末获取源码联系方式 &#x1f4dd; &#x1f345; 查看下方微信号获取联系方式 承接各种定制系统 &#x1f…

Transformer实战-系列教程3:Vision Transformer 源码解读1

&#x1f6a9;&#x1f6a9;&#x1f6a9;Transformer实战-系列教程总目录 有任何问题欢迎在下面留言 本篇文章的代码运行界面均在Pycharm中进行 本篇文章配套的代码资源已经上传 1、整体解读 在文本任务中大量使用了Transformer 架构&#xff0c;因为文本数据是一个序列非常好…

2、安全开发-Python-Socket编程端口探针域名爆破反弹Shell编码免杀

用途&#xff1a;个人学习笔记&#xff0c;欢迎指正&#xff01; 目录 主要内容&#xff1a; 一、端口扫描(未开防火墙情况) 1、Python关键代码: 2、完整代码&#xff1a;多线程配合Queue进行全端口扫描 二、子域名扫描 三、客户端&#xff0c;服务端Socket编程通信cmd命…

vue中使用html2canvas配合jspdf导出pdf(以及在导出时遇到的导出样式问题)

指定页面中导出为pdf格式并打包&#xff0c;使用html2canvas先转为图片格式&#xff0c;在利用jspdf转为pdf&#xff0c;最后下载打包为本地压缩包 yarn add html2canvas yarn add jspdf1. 注册一个插件并挂载 import html2Canvas from html2canvas import JsPDF from jspdf …