vuez 与 Vue3 响应式比较

Vue2 的响应式

对象:通过 defineProperty 对对象的已有属性值的读取和修改进行劫持(监视/拦被)。

数组:通过重写数组、更新数组等一系列更新元素的方法来实现元素修改的劫持。

存在的问题如下:

  1. 对象直接新添加属性或删除已有属性,界面不会自动更新。
  2. 数组直接通过下标替换元素或更新 length,界面不会自动更新 arr[O]= xx。

Vue3 的响应式

通过 Proxy(代理):拦截对data 任意属性的任意(13种)操作,包括属性值的读写、属性的添加、属性的删除等。

通过 Reflect(反射):动态地对被代理对象的相应属性进行特定的操作。

Proxy 官方文档:

https://developer.mozilla.org/zh-CN/docs/ Web/JavaScript/ Reference/Global_Objects/Proxy

Reflect 官方文档:

https:// developer. mozilla.org/zh-CN/ docs/ Web/ JavaScript/ Reference/Global_Objects/Reflect

相关推荐
Aerelin10 小时前
爬虫playwright中的等待机制
前端·爬虫·python
慧慧吖@11 小时前
关于在本地去模拟生产环境检测页面内容注意事项
前端·javascript·vue.js
码农很忙11 小时前
用SpreadJS实现分权限管理:前端技术栈的精准控制实践
前端
黄团团11 小时前
Vue2整合Electron开发桌面级应用以及打包发布(提供Gitee源码)
前端·javascript·vue.js·elementui·electron
勇气要爆发11 小时前
问:LocalStorage、Vuex、Pinia的区别和本质
前端
Aerelin11 小时前
iframe讲解(爬虫playwright的特殊应用)
前端·爬虫·python·html
Drift_Dream11 小时前
IntersectionObserver:现代Web开发的交叉观察者
前端
9***P33411 小时前
前端错误监控工具
前端
东东23312 小时前
GeoJSON 介绍:Web 地图数据的通用语言
前端·javascript·json
之恒君12 小时前
Promise.resolve(x) 等同 new Promise(resolve => resolve(x))?
前端·promise