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

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

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

javascript 复制代码
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 }
)

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

javascript 复制代码
watch(
  () =>
    data.flatMap(item =>
      item.children.flatMap(child => [...child.tags])
    ),
  (newVal) => {
    console.log('所有 tags 改了:', newVal)
  }
)
相关推荐
Jiaberrr3 分钟前
uniapp Vue2 获取电量的独家方法:绕过官方插件限制
前端·javascript·uni-app·plus·电量
Lhuu(重开版22 分钟前
Vue:Ajax
vue.js·ajax·okhttp
谢尔登37 分钟前
【React】React 18 并发特性
前端·react.js·前端框架
Joker`s smile39 分钟前
使用React+ant Table 实现 表格无限循环滚动播放
前端·javascript·react.js
国家不保护废物44 分钟前
🌟 React 魔法学院入学指南:从零构建你的第一个魔法阵(项目)!
前端·react.js·架构
然我1 小时前
从原生 JS 到 React:手把手带你开启 React 业务开发之旅
javascript·react.js·前端框架
import_random1 小时前
[机器学习]svm支持向量机(优势在哪里)
前端
国家不保护废物1 小时前
从刀耕火种到现代框架:DOM编程 vs Vue/React 进化史
前端·vue.js·react.js
陈随易1 小时前
Univer v0.8.0 发布,开源免费版 Google Sheets
前端·后端·程序员
wkj0011 小时前
QuaggaJS 配置参数详解
java·linux·服务器·javascript·quaggajs