我明白了,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的最佳表现。

目录
相关文章
|
4天前
|
JavaScript 前端开发
在Vue2或Vue3中项目中使用 Isotope(同位素) 过滤和排序神奇的布局神器,全网独家实现!
本文介绍了在Vue2或Vue3项目中如何使用Isotope(同位素)布局库来创建动态的网格布局,并提供了详细的代码实现和效果展示,包括过滤和排序功能。
10 0
在Vue2或Vue3中项目中使用 Isotope(同位素) 过滤和排序神奇的布局神器,全网独家实现!
|
4天前
|
JavaScript
基于Vue2或Vue3实现任意上下左右拖拽悬浮的元素,且配置为自定义的全局指令
这篇文章介绍了如何在Vue 2或Vue 3项目中实现一个自定义的全局指令`v-dragSwitch`,用于创建可以任意方向拖拽并悬浮的元素,同时包含边界处理的逻辑。
22 2
基于Vue2或Vue3实现任意上下左右拖拽悬浮的元素,且配置为自定义的全局指令
|
4天前
|
前端开发 JavaScript API
基于Vue3+Hooks实现4位随机数和60秒倒计时
本文介绍了如何在Vue3中使用Hooks API来实现生成4位随机数和执行60秒倒计时的功能,并提供了详细的代码示例和运行效果展示。
21 1
基于Vue3+Hooks实现4位随机数和60秒倒计时
|
4天前
|
数据可视化 JavaScript
Vue3项目使用G6可视化组件实现一个树形机构图
在Vue 3项目中使用G6可视化组件库实现树形机构图的构建和展示。
30 1
Vue3项目使用G6可视化组件实现一个树形机构图
|
3天前
|
JavaScript 算法 API
Vue 3有哪些新特性
【8月更文挑战第16天】Vue 3有哪些新特性
15 1
|
4天前
|
JavaScript
基于Vue3实现简约型侧边栏
本文介绍了如何在Vue3项目中实现一个简约型侧边栏导航,包括配置路由、页面布局和导航交互,以及如何通过Vue Router和条件渲染实现动态内容展示。
22 1
|
4天前
|
JavaScript UED
如何在Vue3项目中使用防抖节流技巧
在Vue 3项目中使用防抖和节流技巧以优化组件性能,包括使用`lodash`库和自定义实现这两种方法。
7 0
如何在Vue3项目中使用防抖节流技巧
|
4天前
|
前端开发 JavaScript
基于Vue3实现鼠标按下某个元素进行拖动,实时改变左侧或右侧元素的宽度,以及点击收起或展开的功能
本文介绍了如何在Vue3项目中实现一个鼠标拖动调整元素宽度的功能,并展示了点击按钮收起或展开侧边栏的效果,提供了完整的实现代码和操作演示。
36 0
基于Vue3实现鼠标按下某个元素进行拖动,实时改变左侧或右侧元素的宽度,以及点击收起或展开的功能
|
4天前
在 Vue3 + ElementPlus 项目中使用 el-autocomplete 控件
本文介绍了在Vue3 + ElementPlus项目中如何使用`el-autocomplete`控件实现自动补全输入功能,并探讨了不同版本ElementPlus中`clearable`属性的兼容性问题。
16 0
在 Vue3 + ElementPlus 项目中使用 el-autocomplete 控件
|
4天前
Vue3使用createVNode和render函数实现仿 Antd 加载动效
本文展示了如何在Vue3项目中使用`createVNode`和`render`函数实现一个仿Ant Design加载动效的自定义组件,并提供了详细的实现代码和使用示例。
8 0
Vue3使用createVNode和render函数实现仿 Antd 加载动效