VUE2和VUE3的区别

  1. 数据响应式的实现不同

vue2中的数据响应式是根据Object,defineProperty实现的,使用这个方法每次只能对一个对象中的一个数据进行数据劫持,若需要将对象中的所有属性都设置为响应式的,则需要递归遍历实现深层次的监听,以此对对象中的数据进行数据劫持,在性能方面表现很差。

vue3中的数据响应式是根据proxy代理实现的,proxy的监听可以针对一整个对象,无需递归遍历,性能更好。

注:数据劫持主要通过上述监听方法中的get和set属性进行实现的

若对象中的某个属性被访问了,会在get方法中进行劫持,在get属性中,将依赖该属性的元素进行收集,统一存放到一个数组中。

当属性值发生改变了,会被set方法进行劫持,在该方法中通知所有依赖该属性的元素进行更新

从而实现数据响应式

  1. 生命周期命名不同

V3中将beforeCreat和created合并成一个setup钩子

  1. 语法API

V2使用的是选项式API,最直观的感受就是写法的局限性很大,需要按照他提供的写法进行书写,由于它的数据和逻辑分散在各个选项中,当组件的逻辑变得复杂时,很难进行维护和理解

V3使用的是组合式API,写法更加灵活,更偏向原生的写法。而且它可以将相同功能的代码编写在一起,可读性和复用性更好

  1. 复用函数

V2中一般通过mixin实现某些功能的复用,会导致命名冲突,被覆盖。

V3可以通过自定义创建一个Hook函数实现功能复用,在需要进行使用的地方调用即可,也会不出现命名冲突的问题。

相关推荐
iiiiyu12 小时前
常用API(SimpleDateFormat类 & Calendar类 & JDK8日期 时间 日期时间 & JDK8日期(时区) )
java·大数据·开发语言·数据结构·编程语言
故事和你9112 小时前
洛谷-数据结构1-4-图的基本应用2
开发语言·数据结构·算法·深度优先·动态规划·图论
用泥种荷花12 小时前
从 0 到 1 做一个支持 NFC 写入的小程序,需要哪些 API?
前端
qq_120840937112 小时前
Three.js 工程向:Clock、deltaTime 与固定步长主循环
开发语言·javascript·ecmascript
小菜同学爱学习12 小时前
夯实基础!MySQL数据类型进阶、约束详解与报错排查
开发语言·数据库·sql·mysql
90程序员13 小时前
纯浏览器解析 APK 信息,不用服务器 | 开源了一个小工具
前端·apk
源码站~13 小时前
基于机器学习的社交媒体舆情分析系统
开发语言·python
用户114818678948413 小时前
Vosk-Browser 实现浏览器离线语音转文字
前端·javascript
江上清风山间明月13 小时前
Vite现代化的前端构建工具详解
前端·webpack·nodejs·vite
PBitW13 小时前
apijson 让前端自己定义接口 —— 但不推荐
前端·apijson