我明白了,Vue3设计与实现-权衡的艺术读后感

简介: 权衡的艺术,看到这个名字,我瞬间脑袋就像个灯泡一样,瞬间一亮。我喜欢,我很想知道vue权衡的艺术,就像上帝为什么要造人一样的艺术(狗头)。好了,开始。

前言

vue3的设计与实现这本书终于到手了噢,还有作者的亲笔签名以及大圣老师的传奇大印。可不能辜负了大圣老师的美意,所以我决定每看一掌都会写一些心得。

权衡的艺术,看到这个名字,我瞬间脑袋就像个灯泡一样,瞬间一亮。我喜欢,我很想知道vue权衡的艺术,就像上帝为什么要造人一样的艺术(狗头)。好了,开始。

书中源码

DOM编程的两种方式

命令式与声明式

作为一个曾经实现过JQuery的人来说,印象是很深刻的,JQuery是基于原生js做了一层封装,封装了很多简易操作的功能。比如DOM的增删改查、简单动画的切入、请求与处理等等。
虽然JQuery是一个类库,但是还是避免不了他基于过程的操作方式,它只是简化过程,但实际上还是在一步一步的操作DOM。

命令式编程更加注重过程,操作DOM是一步一步的来,你需要了解这个具体逻辑以及每一个API的效果,才能够实现你想要的操作DOM的效果。虽然有了JQuery,但是还是会有很多冗余代码。

vue在2016年就开始接触,当时在读大一的觉得它好神奇噢,居然能自动改变数据。那时候我们还在学C#的webform aspx,里面有类似功能的插件,后来发现它是用viewstate和隐藏域来实现的。而vue是纯前端的实现,当时能想到的是 它应该是个观察者,然后通过字符串的替换操作来将 插值运算符改成实际的结果。至于它为啥那么准确的定位,我当时觉得应该是加了id,所以才那么准确的。

声明式编程更加注重结果,不需要你写那么多操作DOM步骤,你只要按照它的方式去声明,就能够自动的帮你操作DOM了,非常的方便,代码看起来更加灵动些。

权衡性能与可维护性

看到这章让我非常感兴趣,很久以前我想过,都说MVVM框架性能很好,但是它引入了那么多代码进去,怎么可能性能好,肯定没有原生的好。因此也曾一度排斥这种框架,以助于后来参加工作了,第一个项目就没用vue而是用JQuery+面向对象的设计模式来封装一个MVC框架来用,感觉那样更加符合大学里的编程方式。
不过后来发现我错了,vue是真香,让我的开发效率提高了很多,从而有很多时间去学更多新东西,而不是冗余的业务代码写很多遍。

vue的是个框架,一般来说框架的性能都不会比你原生操作的性能要好。毕竟不管你用不用,框架都会封装很多层,这么多层,每一层耗费的性能加起来肯定比你直接操作的性能要高。
当然那得是在你了解浏览器的一些原理与特性的基础上,不然在遇到复杂问题时,你写的原生代码未必要比框架的性能高。

vue这个框架给我们带来了开发效率高以及可维护性高的这样诸如此类的好处。毕竟如果你开发项目写成片成片的原生代码,写的时候逻辑是从上往下的没问题,但是代码量会巨长。并且在你不写成片的注释的时候,过几个月你再看,势必会头晕。这个我经历过,一个js文件几千行,密密麻麻的密集恐惧症。

虚拟DOM的性能

创建DOM的时候,通过虚拟DOM来创建DOM是没有你直接创建DOM的性能好。毕竟手动创建DOM我就直接创建了,而虚拟DOM是需要你根据js对象来映射的创建真实DOM。

更新DOM的时候,通过虚拟DOM来更新DOM比你直接更新DOM的性能好,这个在更新的DOM内容越多时越明显。因为你直接更新DOM,比如JQuery,它是不存在复用原来的DOM的,会整片更新,而虚拟DOM是先对比再把有数据变更的DOM更新掉,会复用原来的DOM,非常的精准。

在实际开发中使用虚拟DOM 心智压力小,使用原生JS 心智压力大。

运行时和编译时

书中写了三种,运行时、编译时+运行时、编译时。

运行时,就是有个render函数,会在运行的时候调用render函数,从而将你手写的js对象(虚拟dom)转成DOM。
编译时+运行时,就是有个compiler函数和render函数,compiler函数可以将你写的html字符串转成虚拟dom对象,然后render函数将你的虚拟dom对象转成DOM。
编译时,就是有个compiler函数直接把你的html字符串转成操作DOM的原生js操作,从而没有额外的将虚拟dom转成DOM的那些操作。

vue 是前两种,而Sevlte是最后一种,之前我做过的一个在线md绘图小工具就是基于官方的Sevlte开源项目做的 Graphic Live Editor

总结

第一章让我对vue产生了极大的兴趣噢,之前我对编程都有点厌倦了,看到这本书真的让我又一次焕然而生,就像回到大学时,茶饭不思除了睡觉就是编程的时候。

vue权衡的艺术是 为了降低开发者的使用心智以及开发项目的可维护性,从而创造出这款框架,从性能上来说,可能没有高质量的原生的js操作性能好,但是入手成本低,并且开发出的程序可维护性很高,在大多数情况下性能性能还是很不错的。

虚拟dom的性能在更新时很不错,因为它是真正的局部更新,而不是一直都是偷懒的整片更新,性能损耗的操作是 diff差异时的操作 和 直接修改有变化部分的操作。通过找到差异的地方局部更新,这也是虚拟dom的最佳表现。

目录
相关文章
|
12天前
|
存储 JavaScript 前端开发
vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
【10月更文挑战第21天】 vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
|
15天前
|
API
vue3知识点:provide 与 inject
vue3知识点:provide 与 inject
28 4
vue3知识点:provide 与 inject
|
15天前
|
API
vue3知识点:readonly 与 shallowReadonly
vue3知识点:readonly 与 shallowReadonly
24 1
vue3知识点:readonly 与 shallowReadonly
|
9天前
|
JavaScript 前端开发 开发者
Vue 3中的Proxy
【10月更文挑战第23天】Vue 3中的`Proxy`为响应式系统带来了更强大、更灵活的功能,解决了Vue 2中响应式系统的一些局限性,同时在性能方面也有一定的提升,为开发者提供了更好的开发体验和性能保障。
25 7
|
10天前
|
前端开发 数据库
芋道框架审批流如何实现(Cloud+Vue3)
芋道框架审批流如何实现(Cloud+Vue3)
30 3
|
9天前
|
JavaScript 数据管理 Java
在 Vue 3 中使用 Proxy 实现数据双向绑定的性能如何?
【10月更文挑战第23天】Vue 3中使用Proxy实现数据双向绑定在多个方面都带来了性能的提升,从更高效的响应式追踪、更好的初始化性能、对数组操作的优化到更优的内存管理等,使得Vue 3在处理复杂的应用场景和大量数据时能够更加高效和稳定地运行。
29 1
|
9天前
|
JavaScript 开发者
在 Vue 3 中使用 Proxy 实现数据的双向绑定
【10月更文挑战第23天】Vue 3利用 `Proxy` 实现了数据的双向绑定,无论是使用内置的指令如 `v-model`,还是通过自定义事件或自定义指令,都能够方便地实现数据与视图之间的双向交互,满足不同场景下的开发需求。
29 1
|
11天前
|
前端开发 JavaScript
简记 Vue3(一)—— setup、ref、reactive、toRefs、toRef
简记 Vue3(一)—— setup、ref、reactive、toRefs、toRef
|
12天前
Vue3 项目的 setup 函数
【10月更文挑战第23天】setup` 函数是 Vue3 中非常重要的一个概念,掌握它的使用方法对于开发高效、灵活的 Vue3 组件至关重要。通过不断的实践和探索,你将能够更好地利用 `setup` 函数来构建优秀的 Vue3 项目。
|
15天前
|
JavaScript Java API
vue3知识点:setup
vue3知识点:setup
27 5
下一篇
无影云桌面