Programming_Cepheus 2023-06-02 10:07 采纳率: 45.5%
浏览 19
已结题

React 18.2 根据传递进去的id值获取数组对象里面的数据并给对象赋值

我获取到了父级节点,我想要根据传递进来的父级节点获取到这个节点下的数据,并给对象进行重新赋值。

  // 获取与指定 list item 关联的 treeData  id就是父级节点
// 如果传入的id值没有找到这条数据,就根据传递的id值找到这条数据并重新给treeDataMap 进行赋值
treeDataMap 是一个数组对象

数据结构是这样的:
-------------------------------------------------------------------------------------------------------------------------------------
SL-171848: Array(1)
0: children
: Array(2)
0: {title: {…}, value: 'SL-258005', children: Array(0)}
1: {title: {…}, value: 'SL-990614', children: Array(0)}
----------------------------------------- -------------------------------------------------------------------------------------------
const getTreeDataForListItem = (id) => {
  debugger
  if (treeDataMap[id]) {
    return treeDataMap[id];
  }
  const treeData = fetchDataById(id); // 根据id值获取数据
  treeDataMap[id] = treeData; // 将获取到的数据赋值给treeDataMap
  return treeData;
};

 const fetchDataById = (id) => {
    debugger
    // 使用递归函数遍历整个树形数据结构
    const traverseTreeData = (data, targetId) => {
      debugger
      for (let i = 0; i < data.length; i++) {
        const node = data[i];
  
        // 如果当前节点的 ID 匹配目标 ID,则返回该节点
        if (node.value === targetId) {
          debugger
          return node;
        }
  
        // 否则,递归遍历当前节点的子节点
        const children = node.children || [];
        const result = traverseTreeData(children, targetId);
        if (result) {
          return result;
        }
      }
  
      // 如果未找到与目标 ID 匹配的节点,则返回 null
      return null;
    };
  
    // 调用递归函数以查找与目标 ID 匹配的节点
    const resultNode = traverseTreeData(treeData, id);
  
    // 返回结果节点的数据属性
    return resultNode ? resultNode.data : null;
  };
  

img

img


大概要实现的效果就行 根据传递进来的节点id值,获取到这个属于这个id的数据,把数据赋值给treeDataMap对象。

  • 写回答

0条回答 默认 最新

    报告相同问题?

    问题事件

    • 系统已结题 6月10日
    • 创建了问题 6月2日

    悬赏问题

    • ¥15 MapReduce结果输出到HBase,一直连接不上MySQL
    • ¥15 扩散模型sd.webui使用时报错“Nonetype”
    • ¥15 stm32流水灯+呼吸灯+外部中断按键
    • ¥15 将二维数组,按照假设的规定,如0/1/0 == "4",把对应列位置写成一个字符并打印输出该字符
    • ¥15 NX MCD仿真与博途通讯不了啥情况
    • ¥15 win11家庭中文版安装docker遇到Hyper-V启用失败解决办法整理
    • ¥15 gradio的web端页面格式不对的问题
    • ¥15 求大家看看Nonce如何配置
    • ¥15 Matlab怎么求解含参的二重积分?
    • ¥15 苹果手机突然连不上wifi了?