当前位置: 首页 > news >正文

vue之异步更新队列

1.什么是异步更新队列

Vue 的异步更新队列是一种性能优化策略。当响应式数据发生变化时,Vue 并不会立即触发组件更新,而是将对应的 Watcher 对象 放入一个队列中。在同一个事件循环 中发生的所有数据变更,其对应的 Watcher 都会被去重后缓存到这个队列里。在当前循环的同步任务执行完毕后,Vue 会在 微任务阶段 一次性清空队列,执行所有 Watcher 的更新操作。

2.过程

在对data的数据进行赋值操作时,会触发data对应的watcher,并把watcher中的更新函数推送到待执行的任务队列。vue是基于promise进行微任务的调用,微任务在当前宏任务结束后、下一个宏任务开始前执行,保证了视图更新的及时性,优于 setTimeout (宏任务)。另外在推送过程中,如果对同一个数据进行多次更改,只会推送和更新一次,因为vue内部会基于map表进行去重操作,这有些类似于惰性策略,以保证更新时的性能和减少不必要的重复调用,调用完成后会执行nextTick钩子,以让用户访问到新的节点数据。

3.日常场景应用

const vm = {el: '#app',data: {msg: 'hello'}
}
vm.msg = 'world'
vm.$el.textContent === 'world' // false
Vue.nextTick(() => {
vm.$el.textContent === 'world' // true
})

4.总结

如上所示,数据的异步更新是依赖于JS的EventLoop和微任务机制,它通过解耦数据变更与视图更新,并利用去重和批量处理机制,最大限度地减少了直接操作 DOM 的次数,在保证响应性的同时,实现了极高的渲染性能。

http://www.dtcms.com/a/535854.html

相关文章:

  • 软文推广有哪些企业关键词优化推荐
  • REFramework下载和安装教程(附安装包)
  • 散户如何做手机T0程序化交易(上)
  • JMeter:执行顺序与作用域
  • Java的自定义异常,throw和throws的对比
  • 哪些知名网站用wordpress建设摩托车是名牌吗
  • Apache JMeter下载和安装图文教程(附安装包,适合新手)
  • MySQL查询字段只有中文的数据
  • 基于Docker、Solr和FastAPI的商品搜索微服务架构设计
  • Woodpecker CI 轻量级持续集成系统深度解析
  • 2.2.2.2 大数据方法论与实践指南-Java Web CI/CD 工具
  • 快速学习React-(第二天)-完成井字棋游戏
  • 石家庄网站开发培训家教网站开发公司
  • 如何制作网址快捷方式深圳网站优化怎么做
  • 聊聊Spark的分区
  • 国产之光:奥威BI的AI数据分析平台,重新定义商业智能
  • Android ContentProvier
  • uni-app OCR图文识别
  • 二叉树的多种遍历方式
  • Vue3 + Electron + Node.js 桌面项目完整开发指南
  • 【Node.js】Node.js 模块系统
  • 古籍影文公开古籍OCR检测数据集VOC格式共计8个文件
  • 网站的对比哪些网站是做免费推广的
  • 网站建设的整体流程有哪些?建筑工程网站建站方案
  • 区块链的密码学基石:沙米尔秘密共享(SSS)数学原理详解
  • 单例模式详解:从基础到高级的八种实现方式
  • 改版网站收费wordpress国人主题
  • web3.0是什么
  • 计网:网络层
  • git学习3