• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧
您的位置:首页 > CMS教程 >建站教程 > vue中data改变后让视图同步更新的方法

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

作者:站长图库 字体:[增加 减小] 来源:互联网 时间:2022-04-29

站长图库向大家介绍了vue中data,视图同步更新等相关知识,希望对您有所帮助

这篇文章主要给大家介绍了关于vue中data改变后让视图同步更新的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前言

不久前天看到一个比较有趣的问题,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都可以解决。



分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

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

相关文章

  • 2022-04-29Photoshop制作海底以透明泡泡组成的艺术字
  • 2022-04-29LayUI如何导入excel文件
  • 2022-04-29手把手教你在node中怎么优雅打印全链路日志
  • 2022-04-29Illustrator制作出超仿真的缝线文字效果
  • 2022-04-29MySQL 中 InnoDB 和 MyISAM 区别
  • 2022-04-29Photoshop绘制水晶质感的放大镜效果
  • 2022-04-29Photoshop手工制作精美的格子背景教程
  • 2022-04-29Vue 和 Yii 怎么配合?
  • 2022-04-29技术教程:如何安装ioncube扩展
  • 2022-04-29laravel-admin怎么使用wang-editor富文本插件

文章分类

  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧

最近更新的内容

    • dedecms调用Discuz!X2.5最新帖子和图片的方法
    • PS制作质感的立体字
    • 浅谈微信小程序中引入并使用自带和外部图标的方法
    • 聊聊ThinkPHP3.2.3从php5升级到php7艰辛之路
    • Photoshop制作61儿童节绚丽艺术字教程
    • 京东图床上传接口 PHP源码
    • UEditor新增自定义按钮/UEditor增加自定义插件
    • Dedecms5.7如何将系统的data目录迁移到web以外目录
    • Photoshop使用计算工具调出别致的颜色
    • 解决LNMP环境无法彻底删除原网站目录文件夹的方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有