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 相关文章推荐
详解vue-cli项目在IE浏览器打开报错解决方法
Dec 10 Vue.js
Vue中ref和$refs的介绍以及使用方法示例
Jan 11 Vue.js
vue 页面跳转的实现方式
Jan 12 Vue.js
Vue实现多页签组件
Jan 14 Vue.js
Vue 数据响应式相关总结
Jan 28 Vue.js
vue 项目@change多个参数传值多个事件的操作
Jan 29 Vue.js
vue脚手架项目创建步骤详解
Mar 02 Vue.js
vue中axios封装使用的完整教程
Mar 03 Vue.js
vue3.0 项目搭建和使用流程
Mar 04 Vue.js
vue实现无缝轮播效果(跑马灯)
May 14 Vue.js
vue实现在data里引入相对路径
Jun 05 Vue.js
el-table-column 内容不自动换行的解决方法
Aug 14 Vue.js
vue3如何优雅的实现移动端登录注册模块
开发一个封装iframe的vue组件
如何让vue长列表快速加载
Vue3 Composition API的使用简介
vue+django实现下载文件的示例
vue路由实现登录拦截
vue项目实现分页效果
Mar 24 #Vue.js
You might like
PHP判断远程图片或文件是否存在的实现代码
2014/02/20 PHP
zf框架db类的分页示例分享
2014/03/14 PHP
PHP封装的完整分页类示例
2018/08/21 PHP
jQuery 打造动态渐变按钮 详细图文教程
2010/04/25 Javascript
JavaScript高级程序设计(第3版)学习笔记6 初识js对象
2012/10/11 Javascript
Jquery Validate 正则表达式实用验证代码大全
2013/08/23 Javascript
javascript实现获取浏览器版本、操作系统类型
2015/01/29 Javascript
Jquery中Event对象属性小结
2015/02/27 Javascript
JQuery操作textarea,input,select,checkbox方法
2015/09/02 Javascript
基于jQuery实现选取月份插件附源码下载
2015/12/28 Javascript
BootstrapTable与KnockoutJS相结合实现增删改查功能【一】
2016/05/10 Javascript
Vue.js每天必学之Class与样式绑定
2016/09/05 Javascript
使用JS读取XML文件的方法
2016/11/25 Javascript
Angular ui.bootstrap.pagination分页
2017/01/20 Javascript
Jil,高效的json序列化和反序列化库
2017/02/15 Javascript
PHP自动加载autoload和命名空间的应用小结
2017/12/01 Javascript
javascript中关于类型判断的一些疑惑小结
2018/10/14 Javascript
从零开始实现Vue简单的Toast插件
2018/12/03 Javascript
python编程线性回归代码示例
2017/12/07 Python
Python3实现的简单验证码识别功能示例
2018/05/02 Python
Django视图扩展类知识点详解
2019/10/25 Python
python3实现raspberry pi(树莓派)4驱小车控制程序
2020/02/12 Python
Python视频编辑库MoviePy的使用
2020/04/01 Python
Python字典dict常用方法函数实例
2020/11/09 Python
德国的大型美妆个护电商:Flaconi
2020/06/26 全球购物
文史专业毕业生自荐信
2013/11/17 职场文书
浙大毕业生自荐信
2014/01/26 职场文书
节能宣传周活动总结
2014/05/08 职场文书
保安公司服务承诺书
2014/05/28 职场文书
考试保密承诺书
2014/08/30 职场文书
致百米运动员广播稿5篇
2014/10/13 职场文书
2014年数学教师工作总结
2014/12/03 职场文书
作弊检讨书范文
2015/05/06 职场文书
社区党建工作总结2015
2015/05/13 职场文书
2015年城管执法工作总结
2015/07/23 职场文书
2015年度环卫处工作总结
2015/07/24 职场文书