Vue的响应原理-M

Vue的响应原理

数据发生变化后,会重新渲染页面从而更新视图,这就是Vue响应式。Vue实现数据响应式,是通过数据劫持结合发布订阅者模式来实现的。数据被获取或者修改的时候,会触发监听者对应的回调函数,进行一些逻辑处理。vue2.0用Object.defineProperty()方法,监听的是对象某个属性的获取修改。Vue3.0用的是proxy反向代理,监听的是整个对象属性的修改。
Object.defineProperty()具体怎么监听的:
首先我们需要通过Object.defineProperty()方法把数据(data)设置为getter和setter的访问形式,这样我们就可以在数据被修改时在setter方法设置监视修改页面信息,也就是说每当数据被修改,就会触发对应的set方法,然后我们可以在set方法中去调用操作dom的方法。​ 此外,如果页面有input用v-model绑定数据,我们需要在这种绑定了data的input元素上,添加input事件监听,每当input事件被触发时,就修改对应的data。
vue实现数据响应式,是通过数据劫持侦测数据变化,发布订阅模式进行依赖收集与视图更新。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值