js或者es6 已知id为222的对象数据,如何查询并返回该数据中parentId: 7对应的对象父节点数据的对象

要查询并返回id为222的对象数据中parentId为7对应的对象的父节点数据,我们需要遍历整个data数组,找到id为222的对象,并从其父节点中提取信息。由于您提供的data数组中的对象格式存在问题(例如,对象的键值对应该用花括号{}包围),我将先帮您修正格式,然后提供查询的代码。

修正后的data数组格式如下:

javascript 复制代码
const data = [
    {
        "id": 1,
        "name": "常用指标",
        "parentId": 0,
        "signalTypeIds": "",
        "harmonicTimes": "",
        "children": [
            {
                "id": 7,
                "name": "相电压",
                "parentId": 1,
                "signalTypeIds": {
                    "0": 1,
                    "1": 94,
                    "2": 161,
                    "3": 228,
                    "4": 295
                },
                "harmonicTimes": "",
                "children": [
                    {
                        "children": undefined,
                        "harmonicTimes": "",
                        "id": 222,
                        "label": "A相",
                        "name": "A相",
                        "parentId": 7,
                        "signalTypeIds": { "0": 1, "1": 94, "2": 161, "3": 228, "4": 295 },
                        "value": "A相"
                    }
                ]
            }
        ]
    },
    {
        "id": 3,
        "name": "电压电流功率",
        "parentId": 0,
        "signalTypeIds": "",
        "harmonicTimes": "",
        "children": [
            {
                "id": 4,
                "name": "相电压",
                "parentId": 3,
                "signalTypeIds": {
                    "0": 1,
                    "1": 94,
                    "2": 161,
                    "3": 228,
                    "4": 295
                },
                "harmonicTimes": "",
                "children": []
            }
        ]
    }
];

现在,我们可以使用以下递归函数来查询并返回id为222的对象的父节点数据:

javascript 复制代码
function findParentNodeById(id, data) {
    for (const item of data) {
        if (item.children) {
            for (const child of item.children) {
                if (child.children) {
                    // 递归搜索孙节点
                    const result = findParentNodeById(id, child.children);
                    if (result) return result; // 如果在孙节点中找到,返回结果
                } else if (child.id === id) {
                    // 找到id为222的对象,返回其父节点
                    return child;
                }
            }
        }
    }
    return null; // 如果没有找到,返回null
}

const parentNode = findParentNodeById(222, data);

console.log(parentNode); // 这将输出id为222的对象的父节点数据

这段代码定义了一个findParentNodeById函数,它接受两个参数:要搜索的id和要搜索的数组。函数内部,它遍历提供的数组及其所有子数组,查找id为指定值的对象。当找到id为222的对象时,它返回该对象的父节点数据。如果没有找到匹配的对象,函数返回null

相关推荐
weixin-a153003083161 小时前
【playwright篇】教程(十七)[html元素知识]
java·前端·html
ai小鬼头1 小时前
AIStarter最新版怎么卸载AI项目?一键删除操作指南(附路径设置技巧)
前端·后端·github
wen's1 小时前
React Native 0.79.4 中 [RCTView setColor:] 崩溃问题完整解决方案
javascript·react native·react.js
一只叫煤球的猫2 小时前
普通程序员,从开发到管理岗,为什么我越升职越痛苦?
前端·后端·全栈
vvilkim2 小时前
Electron 自动更新机制详解:实现无缝应用升级
前端·javascript·electron
vvilkim2 小时前
Electron 应用中的内容安全策略 (CSP) 全面指南
前端·javascript·electron
aha-凯心2 小时前
vben 之 axios 封装
前端·javascript·学习
漫谈网络2 小时前
WebSocket 在前后端的完整使用流程
javascript·python·websocket
遗憾随她而去.3 小时前
uniapp 中使用路由导航守卫,进行登录鉴权
前端·uni-app
xjt_09013 小时前
浅析Web存储系统
前端