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 相关文章推荐
springboot+vue实现文件上传下载
Nov 17 Vue.js
Vue组件生命周期运行原理解析
Nov 25 Vue.js
vue中defineProperty和Proxy的区别详解
Nov 30 Vue.js
Vue3+elementui plus创建项目的方法
Dec 01 Vue.js
详解Vue中的自定义指令
Dec 07 Vue.js
vue+elementui通用弹窗的实现(新增+编辑)
Jan 07 Vue.js
vue编写简单的购物车功能
Jan 08 Vue.js
vue 项目@change多个参数传值多个事件的操作
Jan 29 Vue.js
vue中axios封装使用的完整教程
Mar 03 Vue.js
vue中三级导航的菜单权限控制
Mar 31 Vue.js
vue.js Router中嵌套路由的实用示例
Jun 27 Vue.js
vue特效之翻牌动画
Apr 20 Vue.js
vue3如何优雅的实现移动端登录注册模块
开发一个封装iframe的vue组件
如何让vue长列表快速加载
Vue3 Composition API的使用简介
vue+django实现下载文件的示例
vue路由实现登录拦截
vue项目实现分页效果
Mar 24 #Vue.js
You might like
一些被忽视的PHP函数(简单整理)
2010/04/30 PHP
php中取得文件的后缀名?
2012/02/20 PHP
php中filter_input函数用法分析
2014/11/15 PHP
Thinkphp无限级分类代码
2015/11/11 PHP
javascript 对象定义方法 简单易学
2009/03/22 Javascript
js脚本获取webform服务器控件的方法
2014/05/16 Javascript
jquery判断复选框选中状态以及区分attr和prop
2015/12/18 Javascript
完美解决UI-Grid表格元素中多个空格显示为一个空格的问题
2017/04/25 Javascript
浅谈vuex之mutation和action的基本使用
2017/08/29 Javascript
用POSTMAN发送JSON格式的POST请求示例
2018/09/04 Javascript
Javascript柯里化实现原理及作用解析
2020/10/22 Javascript
Vue select 绑定动态变量的实例讲解
2020/10/22 Javascript
vue实现两个区域滚动条同步滚动
2020/12/13 Vue.js
python3生成随机数实例
2014/10/20 Python
详解python中的json的基本使用方法
2016/12/21 Python
Python的时间模块datetime详解
2017/04/17 Python
Python的装饰器使用详解
2017/06/26 Python
Python使用smtp和pop简单收发邮件完整实例
2018/01/09 Python
python3 http提交json参数并获取返回值的方法
2018/12/19 Python
Python子类继承父类构造函数详解
2019/02/19 Python
python实现字符串加密 生成唯一固定长度字符串
2019/03/22 Python
python基于socket实现的UDP及TCP通讯功能示例
2019/11/01 Python
python shutil文件操作工具使用实例分析
2019/12/25 Python
新手入门学习python Numpy基础操作
2020/03/02 Python
Pytorch高阶OP操作where,gather原理
2020/04/30 Python
Python批量修改xml的坐标值全部转为整数的实例代码
2020/11/26 Python
python中pdb模块实例用法
2021/01/15 Python
CSS3实现圆角、阴影、透明效果并兼容各大浏览器
2014/08/08 HTML / CSS
日本高端护肤品牌:Tatcha
2016/08/29 全球购物
凯普林包包西班牙官网:Kipling西班牙
2019/04/12 全球购物
远程调用的原理
2014/07/05 面试题
三年级音乐教学反思
2014/01/28 职场文书
运动会稿件50字
2014/02/17 职场文书
秋季校运会广播稿100字
2014/09/18 职场文书
工作服管理制度范本
2015/08/06 职场文书
小学英语教师研修感悟
2015/11/18 职场文书