时间:2021-05-26
不久前天看到一个比较有趣的问题,vue中data改变后,如何让视图同步更新,搜索了一下,并没有发现解决问题的方法,只能从源码去找解决方法了。
我们都知道,在vue中改变数据后,视图并不是同步更新的。
在vue实例初始化后,会将data设置为响应式对象,当我们执行this.xxx = 1时,会触发这个响应式对象的setter。在setter中,会触发更新,通知所有订阅了xxx的订阅者。但是这个触发更新并不是同步的,它会将所有的watcher都添加到一个队列,并在nextTick之后去更新视图。
这就是vue不能同步更新视图的原因。
知道了原因,总能找到解决方法。
既然是在nextTick的时候去更新视图,这个时候,必然会去执行一个更新视图的方法,那么我们手动在数据改变的时候去执行这个方法,就达到了同步更新视图的目的。
在了解源码后,我们可以发现执行的是watcher.run()这个方法,那么问题来了,怎么去获取这个方法?
想快速了解这一块建议阅读 Vue.js技术揭秘
我们在控制台打印一下this
可以在_watcher这个对象的原型上找到run这个方法,因此问题就解决了。
this.xxx = 1; this._watcher.run()执行以上代码,在更新完数据后,手动更新视图,就可以做到同步的效果。
如果每次想要视图同步更新都要加一句 this._watcher.run() ,那岂不是太麻烦了,因此,我写了一个插件,支持this.xxx = 1 之后就同步更新视图。
这个插件原理很简单,就是在组件的options里边加了一个选项syncData,跟data是类似的,然后放入data里面,created钩子调用的时候重新劫持这部分数据,syncData里边数据改变的时候,自动触发_watch.run(),从而同步更新视图。
插件地址:GitHub地址
讲道理我觉得这个插件并没有什么卵用,理论上这个插件能解决的问题$nextTick都可以解决。
到此这篇关于vue中data改变后让视图同步更新的方法的文章就介绍到这了,更多相关vue视图同步更新内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
用过VUE的童鞋都知道,vue在改变data里面参数可以以直接用this.XXX=XXX,并且视图层也会立即更新呈现,但是这里我想介绍一下微信小程序是怎样操作d
Vue实现响应式后DOM的变化data对象中数据改变是如何追踪的?vue将遍历data对象中所有的属性,并通过Object.defineProperty
1为什么需要状态管理一个Vue组件分为数据(model)与视图(view)。当通过methods中的方法更新数据时,视图也会自动更新。message.vue{{
当vue的data里边声明或者已经赋值过的对象或者数组(数组里边的值是对象)时,向对象中添加新的属性,如果更新此属性的值,是不会更新视图的。{{item.mes
本文实例讲述了VUE实现动态给对象增加属性,并触发视图更新操作。分享给大家供大家参考,具体如下:在开发过程中,我们时常会遇到这样一种情况:当vue的data里边