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中音频wavesurfer.js的使用方法
Feb 20 Vue.js
Vue实现指令式动态追加小球动画组件的步骤
Dec 18 Vue.js
vue 在单页面应用里使用二级套嵌路由
Dec 19 Vue.js
vue仿携程轮播图效果(滑动轮播,下方高度自适应)
Feb 11 Vue.js
vue-router懒加载的3种方式汇总
Feb 28 Vue.js
Vue多选列表组件深入详解
Mar 02 Vue.js
vue前端工程的搭建
Mar 31 Vue.js
vue如何批量引入组件、注册和使用详解
May 12 Vue.js
vue Element-ui表格实现树形结构表格
Jun 07 Vue.js
Vue3.0中Ref与Reactive的区别示例详析
Jul 07 Vue.js
vue使用echarts实现折线图
Mar 21 Vue.js
vue3如何优雅的实现移动端登录注册模块
开发一个封装iframe的vue组件
如何让vue长列表快速加载
Vue3 Composition API的使用简介
vue+django实现下载文件的示例
vue路由实现登录拦截
vue项目实现分页效果
Mar 24 #Vue.js
You might like
php笔记之:php数组相关函数的使用
2013/04/26 PHP
laravel容器延迟加载以及auth扩展详解
2015/03/02 PHP
ThinkPHP和UCenter接口冲突的解决方法
2016/07/25 PHP
基于Codeigniter框架实现的student信息系统站点动态发布功能详解
2017/03/23 PHP
Laravel 简单实现Ajax滚动加载示例
2019/10/22 PHP
用脚本调用样式的几种方法
2006/12/09 Javascript
实现JavaScript中继承的三种方式
2009/10/16 Javascript
JavaScript Event学习第七章 事件属性
2010/02/07 Javascript
不使用XMLHttpRequest实现异步加载 Iframe和script
2012/10/29 Javascript
JS对img进行操作(换图片/切图/轮换/停止)
2013/04/17 Javascript
js基础知识(公有方法、私有方法、特权方法)
2015/11/06 Javascript
jQuery获取DOM节点实例分析(2种方式)
2015/12/15 Javascript
实践中学习AngularJS表单
2016/03/21 Javascript
jQuery通过写入cookie实现更换网页背景的方法
2016/04/15 Javascript
BootStrap中Datetimepicker和uploadify插件应用实例小结
2016/05/26 Javascript
JQuery 设置checkbox值二次无效的解决方法
2016/07/22 Javascript
浅谈JavaScript的计时器对象
2016/12/26 Javascript
javascript prototype原型详解(比较基础)
2016/12/26 Javascript
AngularJS使用ng-inlude指令加载页面失败的原因与解决方法
2017/01/19 Javascript
AngularJs定时器$interval 和 $timeout详解
2017/05/25 Javascript
vue中阻止click事件冒泡,防止触发另一个事件的方法
2018/02/08 Javascript
利用原生JavaScript实现造日历轮子实例代码
2019/05/08 Javascript
electron-vue利用webpack打包实现多页面的入口文件问题
2019/05/12 Javascript
JavaScript判断数组类型的方法
2019/10/23 Javascript
[11:27]《一刀刀一天》之DOTA全时刻20:TI4总奖金突破920W TS赛事分析
2014/06/18 DOTA
Django之无名分组和有名分组的实现
2019/04/16 Python
Python搭建代理IP池实现接口设置与整体调度
2019/10/27 Python
美国大型的健身社区和补充商店:Bodybuilding.com
2016/09/06 全球购物
Belvilla德国:在线预订度假屋
2018/04/10 全球购物
护士自我鉴定
2013/10/23 职场文书
关于是否需要写商业计划书
2014/02/07 职场文书
上级领导检查欢迎词
2015/09/30 职场文书
《西门豹》教学反思
2016/02/23 职场文书
python数据库批量插入数据的实现(executemany的使用)
2021/04/30 Python
Python实现单例模式的5种方法
2021/06/15 Python
python数据可视化JupyterLab实用扩展程序Mito
2021/11/20 Python