js 获取树节点上某节点的最底层叶子节点数据

效果图

数据为某一个节点对象

递归代码

javascript 复制代码
function getLeafNodes(node) {
  if (!node.children || node.children.length === 0) {
    // 如果是叶子节点,返回它的数据
    return [node.data];
  }
  // 如果节点有子节点,递归获取所有叶子节点的数据
  return node.children.flatMap(getLeafNodes);
}

flatMap方法:使用映射函数映射每个元素,然后将结果压缩成一个新数组

之前有个面试题,让把上面的多维数组转换为一维数组,我在那递归,傻批一个,被自己蠢死。每天一个知识点get!

相关推荐
hua872223 分钟前
Golang 构建学习
java·开发语言·学习
2301_803554524 分钟前
qt信号槽机制以及底层实现原理
开发语言·qt
大傻^5 分钟前
LangChain4j RAG 核心:Document、Embedding 与向量存储抽象
开发语言·人工智能·python·embedding·langchain4j
笨笨马甲5 分钟前
Qt 音视频编解码
开发语言·qt
Halo_tjn9 分钟前
Java 三个修饰符 相关知识点
java·开发语言
2401_8830354615 分钟前
C++20概念(Concepts)入门指南
开发语言·c++·算法
番茄去哪了22 分钟前
Java基础面试题day01
java·开发语言·后端·javase·八股·面向对象编程
wuqingshun31415927 分钟前
说说进程和线程的区别?
java·开发语言·jvm
前端小趴菜0528 分钟前
vue3项目优化方案
前端·javascript·vue.js
Elastic 中国社区官方博客1 小时前
用于 Elasticsearch 的 Gemini CLI 扩展,包含工具和技能
大数据·开发语言·人工智能·elasticsearch·搜索引擎·全文检索