VUE3响应式数据

本文探讨Vue3的响应式数据机制,通过对比Vue2的Object.defineProperty和Vue3的Proxy代理,解释数据如何实现变化时的自动更新。响应式数据基于发布者/订阅者模式,利用底层的getter和setter确保数据变化时页面相应地重绘。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

内存中两块空间一个数mydata储存空间,另一个节点对象,在文档树中用于页面显示的,里面有一个innerHTML属性,这个属性决定页面显示效果

前提设置了一个全局变量Let mydata={title:"我也是个数据容器"}

当mydata存储空间修改后,但是innerHTML没有运行,导致页面的mydata没有运行,页面首次加载innerHTML赋值,然后去了变量存储空间中的字符串,显示出来,innerHTML不会再运行,变量存储空间中的数据发生修改,由于innerHTML没有运行所以不会打印修改后的变量在页面显示

 

 

劫持原理

vue2.0采用 es5中的pbject.defineproperty(set()get())

vue3.0采用es6中的proxy代理

响应式数据就是data数据源发生了改变,页面上凡是使用了数据容器的地方就会重新取值重绘

 这种数据容器的就是响应式的

响应式数据的原理:我们传入的data数据源会被vm对象劫持,底层设计采用发布者/订阅者的设计模式设计

设计出来的 底层js语法的Object.defineProty来实现的,watch监听了每一个属性的getter和setter函数

只要属性被修改就会被执行 修改值和刷新页面

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值