我明白了,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 PHP
斩获开发者口碑!SnowAdmin:基于 Vue3 的高颜值后台管理系统,3 步极速上手!
SnowAdmin 是一款基于 Vue3/TypeScript/Arco Design 的开源后台管理框架,以“清新优雅、开箱即用”为核心设计理念。提供角色权限精细化管理、多主题与暗黑模式切换、动态路由与页面缓存等功能,支持代码规范自动化校验及丰富组件库。通过模块化设计与前沿技术栈(Vite5/Pinia),显著提升开发效率,适合团队协作与长期维护。项目地址:[GitHub](https://github.com/WANG-Fan0912/SnowAdmin)。
697 5
|
1月前
|
缓存 前端开发 大数据
虚拟列表在Vue3中的具体应用场景有哪些?
虚拟列表在 Vue3 中通过仅渲染可视区域内容,显著提升大数据列表性能,适用于 ERP 表格、聊天界面、社交媒体、阅读器、日历及树形结构等场景,结合 `vue-virtual-scroller` 等工具可实现高效滚动与交互体验。
208 1
|
1月前
|
缓存 JavaScript UED
除了循环引用,Vue3还有哪些常见的性能优化技巧?
除了循环引用,Vue3还有哪些常见的性能优化技巧?
131 0
|
2月前
|
JavaScript
vue3循环引用自已实现
当渲染大量数据列表时,使用虚拟列表只渲染可视区域的内容,显著减少 DOM 节点数量。
83 0
|
4月前
|
JavaScript API 容器
Vue 3 中的 nextTick 使用详解与实战案例
Vue 3 中的 nextTick 使用详解与实战案例 在 Vue 3 的日常开发中,我们经常需要在数据变化后等待 DOM 更新完成再执行某些操作。此时,nextTick 就成了一个不可或缺的工具。本文将介绍 nextTick 的基本用法,并通过三个实战案例,展示它在表单验证、弹窗动画、自动聚焦等场景中的实际应用。
380 17
|
5月前
|
JavaScript 前端开发 算法
Vue 3 和 Vue 2 的区别及优点
Vue 3 和 Vue 2 的区别及优点
|
5月前
|
存储 JavaScript 前端开发
基于 ant-design-vue 和 Vue 3 封装的功能强大的表格组件
VTable 是一个基于 ant-design-vue 和 Vue 3 的多功能表格组件,支持列自定义、排序、本地化存储、行选择等功能。它继承了 Ant-Design-Vue Table 的所有特性并加以扩展,提供开箱即用的高性能体验。示例包括基础表格、可选择表格和自定义列渲染等。
372 6
|
4月前
|
JavaScript 前端开发 API
Vue 2 与 Vue 3 的区别:深度对比与迁移指南
Vue.js 是一个用于构建用户界面的渐进式 JavaScript 框架,在过去的几年里,Vue 2 一直是前端开发中的重要工具。而 Vue 3 作为其升级版本,带来了许多显著的改进和新特性。在本文中,我们将深入比较 Vue 2 和 Vue 3 的主要区别,帮助开发者更好地理解这两个版本之间的变化,并提供迁移建议。 1. Vue 3 的新特性概述 Vue 3 引入了许多新特性,使得开发体验更加流畅、灵活。以下是 Vue 3 的一些关键改进: 1.1 Composition API Composition API 是 Vue 3 的核心新特性之一。它改变了 Vue 组件的代码结构,使得逻辑组
1448 0
|
6月前
|
JavaScript 前端开发 UED
vue2和vue3的响应式原理有何不同?
大家好,我是V哥。本文详细对比了Vue 2与Vue 3的响应式原理:Vue 2基于`Object.defineProperty()`,适合小型项目但存在性能瓶颈;Vue 3采用`Proxy`,大幅优化初始化、更新性能及内存占用,更高效稳定。此外,我建议前端开发者关注鸿蒙趋势,2025年将是国产化替代关键期,推荐《鸿蒙 HarmonyOS 开发之路》卷1助你入行。老项目用Vue 2?不妨升级到Vue 3,提升用户体验!关注V哥爱编程,全栈开发轻松上手。
407 2
|
6月前
|
JavaScript 前端开发 算法
高效工作流:用Mermaid绘制你的专属流程图;如何在Vue3中导入mermaid绘制流程图
mermaid是一款非常优秀的基于 JavaScript 的图表绘制工具,可渲染 Markdown 启发的文本定义以动态创建和修改图表。非常适合新手学习或者做一些弱交互且自定义要求不高的图表 除了流程图以外,mermaid还支持序列图、类图、状态图、实体关系图等图表可供探索。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~