vue el-tree主键id重复 添加自增id 以及原相同节点同步勾选 同步操作

树数据只提供了nodeId,且存在不同节点重复nodeId的问题,由于树组件的node-key需要唯一性,所有这个时候我们需要给数据添加自增id (延申问题:操作某个节点的时候,同步操作与他nodeId相同的节点),代码如下

复制代码
<template>
  <div>
    <el-tree
      :data="treeList"
      show-checkbox
      ref="tree"
      :check-strictly="false"
      node-key="id"
      :props="props"
      @check-change="treeCheckChange"
    >
    </el-tree>
  </div>
</template>

<script>
export default {
  data() {
    return {
      props: {
        label: "label",
        children: "children",
      },
      initData: [], // 初始化数据
      treeList: [], // 树数据
      idAndNodeId: [], // 非目录节点id与nodeId直接的关系
      nodeIdMap: {}, // 非目录节点id和nodeId的关系对象 具体作用往下看
    };
  },

  mounted() {
    var arr = [
      {
        nodeId: "1",
        nodeName: "目录1",
        parentId: "-1",
        nodeType: 1,
        children: [
          {
            nodeId: "001",
            nodeName: "子节点1",
            nodeType: 2,
            parentId: "1",
          },
          {
            nodeId: "002",
            nodeName: "子节点2",
            nodeType: 2,
            parentId: "1",
          },
          {
            nodeId: "003",
            nodeName: "子节点3",
            nodeType: 2,
            parentId: "1",
          },
        ],
      },
      {
        nodeId: "2",
        nodeName: "目录2",
        parentId: "-1",
        nodeType: 1,
        children: [
          {
            nodeId: "001",
            nodeName: "子节点1",
            nodeType: 2,
            parentId: "2",
          },
          {
            nodeId: "002",
            nodeName: "子节点2",
            nodeType: 2,
            parentId: "2",
          },
          {
            nodeId: "004",
            nodeName: "子节点24",
            nodeType: 2,
            parentId: "2",
          },
        ],
      },
    ];
    this.id = 0;
    arr = this.circulationTreeData(arr);
    this.treeList = arr;

    this.idAndNodeId = [];
    this.getIdAndNodeId(arr, 1);

    // 生成一个nodeIdMap
    // 遍历数组,将每个对象的nodeId作为属性名,将对象存入属性值中
    // 例如:{ "001": [{...}, {...}], "002": [{...}, {...}] }
    // 这样查找相同nodeId的设备时直接通过属性名取就行了
    var mapKey = "nodeId";
    this.nodeIdMap = this.idAndNodeId.reduce((carry, item) => {
      if (item.nodeType == 2) {
        carry[item[mapKey]] = carry[item[mapKey]] || [];
        carry[item[mapKey]].push(item);
      }
      return carry;
    }, {});
  },

  methods: {
    // 递归处理数据 添加自增id
    circulationTreeData(data) {
      let children = [];
      data.forEach((item, index) => {
        if (item.children && item.children.length > 0) {
          children.push({
            ...item,
            label: item.nodeName,
            id: this.id++,
            parentId: item.parentId,
            children: this.circulationTreeData(item.children),
          });
        } else {
          children.push({
            ...item,
            label: item.nodeName,
            id: this.id++,
            parentId: item.parentId,
          });
        }
      });
      return children;
    },
    //递归获取id和node_id的联系
    getIdAndNodeId(data, level) {
      data.forEach((item) => {
        if (item.children && item.children.length > 0) {
          this.getIdAndNodeId(item.children, level + 1);
        } else {
          this.idAndNodeId.push({
            ...item,
            level: level,
          });
        }
      });
    },
    // 节点勾选
    treeCheckChange(data, ischeck) {
      if (data.nodeType == 1) return;
      // 方法1 遍历idAndNodeId查找相同nodeId的节点 速度慢不推荐
      // if (ischeck) {
      //   this.idAndNodeId.forEach((item) => {
      //     if (item.nodeId == data.nodeId) {
      //       this.$refs.tree.setChecked(item.id, true);
      //     }
      //   });
      // } else {
      //   this.idAndNodeId.forEach((item) => {
      //     if (item.nodeId == data.nodeId) {
      //       this.$refs.tree.setChecked(item.id, false);
      //     }
      //   });
      // }
      // 方法2 直接取对象对应属性 速度快 推荐!!!
      let arrs = this.nodeIdMap[data.nodeId] || [];
      console.log(arrs);
      arrs.forEach((item) => {
        if (item.id != data.id) this.$refs.tree.setChecked(item.id, ischeck);
      });
    },
  },
};
</script>
相关推荐
像是套了虚弱散1 小时前
DevEco Studio与Web联合开发:打造鸿蒙混合应用的全景指南
开发语言·前端·华为·harmonyos·鸿蒙
衬衫chenshan1 小时前
【CTF】强网杯2025 Web题目writeup
前端
飞翔的佩奇2 小时前
【完整源码+数据集+部署教程】【天线&水】舰船战舰检测与分类图像分割系统源码&数据集全套:改进yolo11-repvit
前端·python·yolo·计算机视觉·数据集·yolo11·舰船战舰检测与分类图像分割系统
哆啦A梦15883 小时前
点击Top切换数据
前端·javascript·vue.js
程序猿追3 小时前
Vue组件化开发
前端·html
艾德金的溪4 小时前
redis-7.4.6部署安装
前端·数据库·redis·缓存
小光学长4 小时前
基于Vue的2025年哈尔滨亚冬会志愿者管理系统5zqg6m36(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
@PHARAOH4 小时前
WHAT - 受控组件和非受控组件
前端·javascript·react.js
生莫甲鲁浪戴4 小时前
Android Studio新手开发第二十六天
android·前端·android studio
JH30734 小时前
B/S架构、HTTP协议与Web服务器详解
前端·http·架构