vue2响应式原理与vue3响应式原理对比
VUE2.0
- 核心
- 对象:通过Object.defineProtytype()对对象的已有属性值的读取和修改进行劫持
- 数组:通过重写数组更新数组一系列更新元素的方法来实现元素的修改的劫持
Object.defineProperty(data,'count',{ get() {}, set() {} })
``
- 问题
- 对象直接新添加的属性或删除已有属性,界面不会自动动更新
- 直接通过下标跟元素或更新length,界面不会自动更新
VUE3.0
- 核心
- 通过Proxy代理,拦截对data任意属性的任意操作,包括属性值的读写,属性的添加,属性的删除等
- 通过Reflect: 动态对被代理对象的相应属性进行特定的操作
new Proxy(data, { //拦截读取属性值 get (target,prop) { return Reflect.get(target, prop) }, //拦截设置属性值或添加新属性 set (target, prop, value) { return Relect.set(target, prop, value) }, deleteProperty (target, prop) { return Reflect.deleteProperty(target, prop) } }) proxy.name = 'tom'
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了