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

vue复杂数据类型多层嵌套的监听

vue复杂数据类型多层嵌套的监听

本来看前辈的做法是watch的嵌套,遇到这种复杂的数据结构还是不多,分享一下前辈的做法

let stopChildWatchList = []  // 用于存放每个子监听器watch(() => data,(val) => {// 清除旧监听stopChildWatchList.forEach(stop => stop())stopChildWatchList = []val.forEach((item, i) => {item.children.forEach((child, j) => {const stop = watch(() => child.tags,(newTags) => {console.log(`data[${i}].children[${j}].tags changed:`, newTags)},{ deep: true })stopChildWatchList.push(stop)})})},{ deep: true, immediate: true }
)

后面我感觉有点不太好读,就去找了一下另一种做法,比较易懂,给自己做个记号

watch(() =>data.flatMap(item =>item.children.flatMap(child => [...child.tags])),(newVal) => {console.log('所有 tags 改了:', newVal)}
)
http://www.xdnf.cn/news/6611.html

相关文章:

  • Python之三大基本库——Matplotlib
  • 基于 React Hook 封装 Store 的三种方案
  • 嵌入式故障码管理系统设计实现
  • 问题 | 国内外软件定义卫星最新进展研究
  • MySQL 高可用
  • DevExpressWinForms-RichEditControl-基础应用
  • 若依框架SpringBoot从Mysql替换集成人大金仓(KingBase)数据库
  • 【linux unbind 设备驱动】
  • API 加速方案:如何使用 Redis 与 Memcached 进行高效缓存优化
  • SpringBoot常用注解详解
  • 【蓝桥杯省赛真题50】python字母比较 第十五届蓝桥杯青少组Python编程省赛真题解析
  • ubuntu22鼠键失灵恢复记录笔记chatgpt解决
  • JavaScript性能优化实战(10):前端框架性能优化深度解析
  • nosqlbooster pojie NoSQLBooster for MongoDB
  • Android studio 实现弹出表单编辑界面
  • Cadence sch 删除原理图位号下划线
  • neo4j框架:ubuntu系统中neo4j安装与使用教程
  • c++20引入的三路比较操作符<=>
  • Linux-进程概念(一)
  • WAS和Tomcat的对比
  • 如何查询Ubuntu系统中最大的几个目录以G单位显示大小,从大到小排列?
  • 我用 CodeBuddy 开发了一个颜色命名搜索器 —— ColorNameHub 的诞生记
  • 在 Kotlin 中,什么是解构,如何使用?
  • 探索嵌入式硬件的世界:技术、应用与未来趋势
  • 知识蒸馏实战:用PyTorch和预训练模型提升小模型性能
  • LeetCode 746 使用最小花费爬楼梯
  • java -jar命令运行 jar包时如何运行外部依赖jar包
  • IEEE 列表会议第五届机器人、自动化与智能控制国际会议
  • python怎么将函数设置为保护状态
  • Suna: 开源多面手 AI 代理