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

记录element-plus树型表格的bug

问题描述

如果数据的子节点命名时children,就没有任何问题,如果后端数据结构子节点是其他名字,比如thisChildList就有bug

  const tableData = [
    {
      id: 1,
      date: '2016-05-02',
      name: 'wangxiaohu',
      address: 'No. 189, Grove St, Los Angeles',
      selectedAble: true,
      thisChildList: [
        {
          id: 131,
          date: '2016-05-01',
          name: 'wangxiaohu',
          address: 'No. 189, Grove St, Los Angeles',
          selectedAble: true,
          thisChildList: [
           ...
          ]
        },
        
  ]

解决

参考大佬的代码
传送门


// 递归
  const setChildren = (children, type) => {
    // 编辑多个子层级
    children.map((j) => {
      toggleSelection(j, type)
      if (j.thisChildList) {
        setChildren(j.thisChildList, type)
      }
    })
  }

  // 选中父节点时,子节点一起选中取消
  const select = (selection, row) => {
    console.log('select!!')

    const hasSelect = selection.some((el) => {
      return row.id === el.id
    })
    console.log('hasSelect', hasSelect)
    if (hasSelect) {
      if (row.thisChildList) {
        // 解决子组件没有被勾选到
        setChildren(row.thisChildList, true)
      }
    } else {
      // 解决点击父组件取消选中,子级也跟着取消
      if (row.thisChildList) {
        setChildren(row.thisChildList, false)
      }
    }
  }
  const toggleSelection = (row, select) => {
    if (row) {
      // 通过使用 nextTick 来延迟执行后续的代码,以确保在更新表格的选中状态之前先进行其他可能的 DOM 更新
      nextTick(() => {
        // 这里 && 的作用是 如果左侧表达式的值为真值,则返回右侧表达式的值;
        // 否则,返回左侧表达式的值。如果左侧表达式的值为假值,则整个表达式的结果也为假值。

        // toggleRowSelection用于多选表格,切换某一行的选中状态, 如果使用了第二个参数,则可直接设置这一行选中与否
        multipleTable.value && multipleTable.value.toggleRowSelection(row, select)
        // 也可以写成 multipleTable.value?.toggleRowSelection(row, select)
      })
    }
  }

  // 选择全部 默认全选框只能影响第一级的 二、三等级别不会联动
  //   当用户手动勾选全选 Checkbox 时触发的事件
  const selectAll = (selection) => {
    console.log('selectAll——————selection', selection)

    // tabledata第一层只要有在selection里面就是全选
    const isSelect = selection.some((el) => {
      const tableDataIds = tableData.map((j) => j.id)
      return tableDataIds.includes(el.id)
    })
    // tableDate第一层只要有不在selection里面就是全不选
    const isCancel = !tableData.every((el) => {
      const selectIds = selection.map((j) => j.id)
      return selectIds.includes(el.id)
    })
    if (isSelect) {
      selection.map((el) => {
        if (el.thisChildList) {
          // 解决子组件没有被勾选到
          setChildren(el.thisChildList, true)
        }
      })
    }
    if (isCancel) {
      tableData.map((el) => {
        if (el.thisChildList) {
          // 解决子组件没有被勾选到
          setChildren(el.thisChildList, false)
        }
      })
    }
  }
  //   const selectionChange = (val) => {
  //     console.log(val)
  //   }

但仍然有问题,比如3级节点选中,他的父级节点无动于衷,不会联动

解决2

或者把thisChildList 改成children

function renameChildListToChildren(data) {
  if (!Array.isArray(data)) {
    return data;
  }
  return data.map(item => {
    const newItem = { ...item };
    if (newItem.thisChildList) {
      newItem.children = renameChildListToChildren(newItem.thisChildList);
      delete newItem.thisChildList;
    }
    return newItem;
  });
}

const newData = renameChildListToChildren(tableData);
console.log(newData);

但是官方也有这个问题
在这里插入图片描述
二级不能影响一级的选中,有bug

相关文章:

  • MySQL常用命令集
  • linux ln命令-linux软链接、硬链接-linux软、硬链接的区别(一):硬链接
  • 【ArcGIS微课1000例】0096:dem三维块状表达(层次地形模型)
  • Java实现学生信息管理系统:从Excel中提取数据的实用方法
  • STM32MP135开发板助力电力行业,IEC61850协议移植笔记
  • 关于使用js的循环语句打印一个金字塔的三种方案
  • 百川终入海 ,一站式海量数据迁移工具 X2Doris 正式发布
  • Oracle RMAN全备脚本(正式测试可行)
  • 【Redis】Redis集群方案应该怎么做 都有哪些方案
  • 安装配置hive
  • 电视盒子哪个好?博主分享口碑网络电视盒子推荐
  • 软件工程知识梳理0-概述
  • Redis核心技术与实战【学习笔记】 - 6.Redis 的统计操作处理
  • C# wpf 字体图标预览,html字符与unicode转换
  • 代码随想录训练营第三十八天打卡| 509. 斐波那契数 70. 爬楼梯 746. 使用最小花费爬楼梯
  • React + react-device-detect 实现设备特定的渲染
  • Python——将Pyaudio的frame音频数据转换成wave格式
  • SpringBoot使用Rabbit详解含完整代码
  • LVS负载均衡对udp流量进行参数调整一例
  • 点击侧边栏菜单跳转到main 页面
  • 巴基斯坦称对印度发起军事行动
  • 人民日报钟声:平等对话是解决大国间问题的正确之道
  • 马云再次现身阿里打卡创业公寓“湖畔小屋”,鼓励员工坚持创业精神
  • 上海“世行对标改革”的税务样本:设立全国首个税务审判庭、制定首个税务行政复议简易程序
  • 2025中国品牌日上海践行活动启动,将建设品牌生态交互平台
  • “爱鸟周”为何不能像FI和花展那样“市区联动”