vue中data改变后让视图同步更新的方法


Posted in Vue.js onMarch 29, 2021

前言

不久前天看到一个比较有趣的问题,vue中data改变后,如何让视图同步更新,搜索了一下,并没有发现解决问题的方法,只能从源码去找解决方法了。

原因

我们都知道,在vue中改变数据后,视图并不是同步更新的。

在vue实例初始化后,会将data设置为响应式对象,当我们执行this.xxx = 1时,会触发这个响应式对象的setter。在setter中,会触发更新,通知所有订阅了xxx的订阅者。但是这个触发更新并不是同步的,它会将所有的watcher都添加到一个队列,并在nextTick之后去更新视图。

这就是vue不能同步更新视图的原因。

解决方法

知道了原因,总能找到解决方法。

既然是在nextTick的时候去更新视图,这个时候,必然会去执行一个更新视图的方法,那么我们手动在数据改变的时候去执行这个方法,就达到了同步更新视图的目的。

在了解源码后,我们可以发现执行的是watcher.run()这个方法,那么问题来了,怎么去获取这个方法?

想快速了解这一块建议阅读 Vue.js技术揭秘

我们在控制台打印一下this

vue中data改变后让视图同步更新的方法

可以在_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.js 相关文章推荐
快速解决vue2+vue-cli3项目ie兼容的问题
Nov 17 Vue.js
vue添加自定义右键菜单的完整实例
Dec 08 Vue.js
vue实现购物车的小练习
Dec 21 Vue.js
vue使用require.context实现动态注册路由
Dec 25 Vue.js
详解Vue的sync修饰符
May 15 Vue.js
vue点击弹窗自动触发点击事件的解决办法(模拟场景)
May 25 Vue.js
Vue实现动态查询规则生成组件
May 27 Vue.js
vue+element ui实现锚点定位
Jun 29 Vue.js
Vue+TypeScript中处理computed方式
Apr 02 Vue.js
vue3种table表格选项个数的控制方法
Apr 14 Vue.js
vue封装数字翻牌器
Apr 20 Vue.js
Vue组件化(ref,props, mixin,.插件)详解
May 15 Vue.js
vue3如何优雅的实现移动端登录注册模块
开发一个封装iframe的vue组件
如何让vue长列表快速加载
Vue3 Composition API的使用简介
vue+django实现下载文件的示例
vue路由实现登录拦截
vue项目实现分页效果
Mar 24 #Vue.js
You might like
ecshop 批量上传(加入自定义属性)
2012/03/20 PHP
自定义php类(查找/修改)xml文档
2013/03/26 PHP
php5.5中类级别的常量使用介绍
2013/10/02 PHP
php使用unset()删除数组中某个单元(键)的方法
2015/02/17 PHP
thinkPHP中volist标签用法示例
2016/12/06 PHP
实现php删除链表中重复的结点
2018/09/27 PHP
PHP+Redis链表解决高并发下商品超卖问题(实现原理及步骤)
2020/08/03 PHP
Javascript编写2048小游戏
2015/07/07 Javascript
jQuery简单实现仿京东分类导航层效果
2016/06/07 Javascript
原生JS实现垂直手风琴效果
2017/02/19 Javascript
HTML5+Canvas调用手机拍照功能实现图片上传(上)
2017/04/21 Javascript
JavaScript选取(picking)和反选(rejecting)对象的属性方法
2017/08/16 Javascript
2种简单的js倒计时方式
2017/10/20 Javascript
springmvc接收jquery提交的数组数据代码分享
2017/10/28 jQuery
three.js实现3D影院的原理的代码分析
2017/12/18 Javascript
使用 Vue-TCB 快速在 Vue 应用中接入云开发的方法
2020/02/10 Javascript
vue在响应头response中获取自定义headers操作
2020/07/24 Javascript
python素数筛选法浅析
2018/03/19 Python
PyQt4实现下拉菜单可供选择并打印出来
2018/04/20 Python
python文件拆分与重组实例
2018/12/10 Python
Pandas删除数据的几种情况(小结)
2019/06/21 Python
Django admin.py 在修改/添加表单界面显示额外字段的方法
2019/08/22 Python
Python3+Appium安装及Appium模拟微信登录方法详解
2021/02/16 Python
HTML5自定义视频播放器源码
2020/01/06 HTML / CSS
HTML5中外部浏览器唤起微信分享功能的代码
2020/09/15 HTML / CSS
亚洲独特体验旅游专家:eOasia
2018/08/15 全球购物
商场端午节活动方案
2014/01/29 职场文书
高三毕业典礼主持词
2014/03/27 职场文书
初中班主任寄语
2014/04/04 职场文书
工业设计毕业生自荐信
2014/04/13 职场文书
抗洪救灾感谢信
2015/01/22 职场文书
2015个人半年总结范文
2015/03/09 职场文书
安全员岗位职责范本
2015/04/11 职场文书
在校证明模板
2015/06/17 职场文书
2015年治庸问责工作总结
2015/07/27 职场文书
高一地理教学工作总结
2015/08/12 职场文书