// 组织机构数深度遍历获取某个机构是否在数据中0
export function recursion(data: any, filterData: any) {
let hasFound = false,// 表示是否有找到id值
result = null;
const filter = (data: any) => {
if (Array.isArray(data) && !hasFound) {
// 判断是否是数组并且没有的情况下,
data.forEach(item => {
if (item.id === filterData.curOrgId) {
// 数据循环每个子项,并且判断子项下边是否有id值
result = item; // 返回的结果等于每一项
hasFound = true; // 并且找到id值
} else if (item.children) {
filter (item.children); // 递归调用下边的子项
}
});
}
};
filter (data); // 调用一下
return hasFound;
}
recursion(data, filterData);
data: json(树形)
filterData:要过滤的某个节点
也是在网上找的解决方案 !!!!

该代码段展示了一个JavaScript函数`recursion`,用于深度遍历树形数据结构,查找指定ID的组织机构节点。函数接受两个参数:整个数据树和要过滤的目标节点ID。通过递归遍历数据,当找到目标ID时,设置标志`hasFound`为真并返回匹配的节点。若遍历完整棵树仍未找到,则返回false。
1591

被折叠的 条评论
为什么被折叠?



