当前位置:首页 > 生活百科

前端使用vue的好处(vue的特点及优势)

栏目:生活百科日期:2025-03-30浏览:0

今天我们就来看看 vue3 相比 vue2 的优点有些啥?

为啥有些人说:自从写了 ts vue3 再也回不到 vue2 啦!

vue3 到底哪里好?有的人回不到 vue2,而有的人去不了vue3!喜欢的点赞收藏,复盘不迷路!

一、Vue3 新增的几个亮点:

Performance:性能优化Tree-shaking :支持摇树优化Composition API :组合式api新增组件:Fragment、Teleport、Supense更好地支持 tsCustom Render API:自定义渲染器

二、性能方面的提升

在性能方面,vue3 相比 vue2 ,性能提升了 1.3 ~ 2 倍左右。我们就来看看它是在哪些方面,如何提升的?

2.1、响应式性能提升

1&> diff方法优化

diff 算法是虚拟 DOM 技术的必然产物,它会对新旧 DOM 进行比较,然后将变化的 DOM 更新在真实的 DOM 上。

在 vue2 中,数据发生变化的时候,会生成一个新的 DOM 树,然后和之前的 DOM 树进行比较,找到不同的节点然后更新到真实的 DOM 上,比较的过程中,会对没有发生改变的 DOM 也都会进行比较,就会消耗一定的时间。

在 vue3 中,在创建虚拟 DOM 的时候,会根据 DOM 中的内容添加一个静态标记,在数据发生改变的时候,就会带着静态标记的节点去对比,能够快速找到变化的 DOM 。

2&> 事件侦听器缓存

默认情况下onClick会被视为动态绑定,所以每次都会追踪它的变化

但是因为是同一个函数,所以不用追踪变化,直接缓存起来复用即可

3&> ssr渲染

当存在大量静态内容时,这些内容会被当做纯字符串推进一个 buffer 内,即使存在动态绑定,也会通过模板插值潜入进去,这样会比虚拟 DOM 渲染快得多。

2.2、代码体积方面

打包大小减少41%。

vue3 移除了一些不常用的 API,如:inline-template、filter 等,使用 tree-shaking。

Tree Shaking 摇树优化,指的就是当我们引入一个模块的时候,不引入这个模块的所有代码,只引入我们需要的代码。

在 vue2 中,很多函数都挂载到全局 Vue 对象上,如:nextTick、set 函数等,虽然我们不常用,但打包时只要引入 Vue 这些全局函数会打包进 bundle 中。而 vue3 中,引入tree-shaking,所有的 API 都通过 ES6 模块化的方式引入,这样就能够让 webpack 或 rollup 等打包工具在打包时,就会自动对没有用到的 API 进行剔除,最小化 bundle 体积。

初次渲染快55%, 更新渲染快133%。组件选择了按需引入,使得打包后的体积也更小了,所以项目运行的时候速度更快,更顺畅了!

2.3、编译被优化

1&> 静态提升

在 vue2 中,无论元素是否参与更新,每次都会重新创建然后再渲染。

vue3 使用静态提升后,对于不参与更新的元素,只会被创建一次,在渲染时直接复用就好了。

2&> Fragment

模板内不用再创建一个唯一根节点,可以直接放同级标签和内容。就相当于少了一个节点嵌套渲染。

三、选项式 api VS 组合式 api

3.1、vue3 的组合式 api 相对来说,更有利于维护和封装。

3.2、组合式 api 高内聚,低耦合。

在 vue2 中采用选项式 api ,会在 vue 文件的 data、methods、watch、computed 中定义属性和方法,共同处理页面逻辑,多个功能相互交叉,缠绕在一起,代码过于分散。

而 vue3 新增了组合式 api ,一个功能模块代码会集中到一起,实现高内聚,低耦合。提高代码的可读性和可维护性,基于函数组合的 api 更好地重用逻辑代码。

组合式api 与 选项式api 对比如下图:

每个颜色,都代表着一个功能。

3.3、不宜出现 DOM 元素不存在问题。

vue3 中用 setup 函数代替了 vue2 中的 beforeCreate 和 created 。有些同学有时候会在 created 中操作 DOM 元素,有时候报错了,就在那纳闷看不出来问题,为了没有反应。使用 setup 之后,就不容易出现该问题了。

注意:

vue3 的组合式 api 中的 onUnmounted 代替了 vue2 中的 beforeDestory。

vue3 的组合式 api unmounted 代替了 vue2 中的 destoryed 。

四、proxy 相对 Object.defineProperty 优点有哪些?

proxy 和 Object.defineProperty 都是来实现响应式数据的。

vue3 使用 proxy 来代替 vue2 的 Object.defineProperty 效率更高,值得学习。

1&> vue2 利用 Object.defineProperty 来劫持 data 数据的 getter 和 setter 操作,使得 data 在被访问或赋值时,动态更新绑定的 template 模板。而 Object.defineProperty 必须遍历所有的预值才能劫持每一个属性,这一缺点正好能够被 proxy 解决。

proxy 相比 Object.defineProperty 优点分别为:

代码的执行效果更快。proxy 可以直接监听对象而不是它的属性。proxy 可以直接监听数组的每个元素的变化。proxy 不需要初始化的时候遍历所有属性,如果有多层嵌套的话,只访问某个属性的时候,proxy 能够快速访问到,而 Object.defineProperty 还需要遍历所有属性,然后逐级向下访问。proxy 返回的是一个新对象,可以直接操作新对象而达到目标。而 Object.defineProperty 操作的是原对象,只能遍历对象属性然后对其直接修改。proxy 有 13 种拦截方法,不限于 apply、ownKeys、deleteProperty 等,而 Object.defineporperty 不具备。

2&> defineProperty 无法监听对象新增属性以及无法跟踪数组索引以及数组 length 的问题,proxy 正好解决了该问题。

在 vue2 中,我们给对象新增一个属性时,如果新增属性的值发生改变的时候,我们发现视图并没有更新,因为新增属性是无法监听到的。同样的,通过下标直接改变数组,视图也是无法更新的,也是因为监听不到。

在 vue3 中新增 proxy ,解决了这些问题。

五、更好的 ts 支持

vue2 不适合使用 ts,在于它的 Options API 风格。

options 是一个简单的对象,而 ts 是一种类型系统、面向对象的语法,两个不匹配。

vue3 新增了 defineComponent 函数,使组件在 ts 下,更好的利用参数类型推断。如:reactive 和 ref 很具有代表性。

六、更先进的组件

1&> Fragment

在 vue2 中,每个模板必须有一个根节点,否则就会报错。

vue3 中可以不需要根节点,多个元素或标签可并列存在。

2&> Teleport

传送门。可以把 teleport 中的内容添加到任意的节点内,对于嵌套较深的组件来说绝对是一个福音。

3&> Supense

允许程序在等待异步组件渲染一些后备的内容,可以让我们创建一个平滑的用户体验。

总结:

vue 目前是国内最火的前端框架之一,vue3 性能提升、运行速度也比 vue2 好很多。

总之 vue3 就是:

让项目更快让代码更少更易于维护让我们开发更快,加班更少

“前端使用vue的好处(vue的特点及优势)” 的相关文章

shell脚本判断文件是否存在出错(shell脚本读取配置文件

在运维工作中,为保证业务的正常运行,我们需要定时查看指定的进程是否还存在,一旦进程退出了,说明服务可能存在问题,运维工程师就可以在第一时间处理问题。今天就跟大家...

免费的网络人远程控制软件手机版(远程读取微信聊天记录

ToDesk是一款安全流畅的远程控制软件,该软件具有安全可靠、高效稳定、简单易用、高清流畅等特点,虽然部分功能限制个人免费使用,但小编实测软件体验还是非常不错的...

中国物流专业大学排名,2020年物流专业的就业前景及方向

1、北京科技大学专业特色1985年组建了物流工程教研室,当年开始招收物流工程研究方向的硕士研究生。北科大拥有全国第一所专门从事物流教育和研究的学术机构,承担过多...

免费手机企业网站建设平台(新手0基础1个小时也可以做出

最近和朋友聊天,听说他的地方站自从建立了手机端论坛,人气就越来越好,由衷地为他高兴。同时,自己维护的微信公众号前一段时间也希望吸引更多的读者来阅读讨论,希望通过...

大型超市门口适合做什么生意(最值投资的创业项目介绍)

知道开一家快消茶饮店最重要的是什么吗?最重要的就是流量,而且是人流量,缓慢的人流量,而不是匆匆而行的人。所以,开在一家超市入口的茶饮店,远比开在道路旁边的茶饮店...

关键字挖掘工具有哪些,5个长尾词挖掘方法介绍

关键词搜索结果是目前让卖家的商品在亚马逊展示给买家的最重要形式。只有当卖家的商品中包含买家输入的单词时,才会呈现给潜在买家。关键词不但是增加卖家商品曝光量的重...

什么品牌电动车好,四款高性价比电动车推荐

随着当代社会的交通不断发达,各种交通工具应运而生。汽车的拥堵让许多人对于交通工具的选择转向了更为方便快捷的电动车,这也是导致近两年电动车迅猛发展的主要原因。产品...

信息安全管理认证的过程(iso信息安全管理体系讲解)

信息安全认证分为很多种,但是大家常说的信息安全类认证主要分为信息安全服务资质认证、ISO27001信息安全管理体系认证,你知道吗?下面就跟小卓一起来了解一下这两...

乒乓球拍推荐,盘点最适合业余高手的五款球拍

黑马探板,探无止境,知无不言。1.729开蒙12.敢搏禅3.银河紫龙4374.阿迪达斯StrikeWood75.雷神迅猛V7RS开蒙1关键词:持球、稳当、手感舒...

专利价值如何评估,专利价值评估方法

当今市场竞争的浪潮中,很大程度上就是知识产权的竞争、现状态为“没有知识产权的企业没有核心竞争力,没有未来”,尤其是专利的竞争。在商业收购案以及商战中都可以看出,...