使用 JavaScript 查找并扁平化特定分类 ID 的子项

使用 javascript 查找并扁平化特定分类 id 的子项

本文档提供了一个 JavaScript教程,用于从嵌套的分类数据结构中提取特定分类ID的所有子项,并将结果扁平化为一个数组。它涵盖了处理不同场景的逻辑,包括指定分类ID和未指定分类ID的情况,并提供了可复用的代码示例。

场景描述

假设我们有一个嵌套的分类数据结构,每个分类都有 id、name、count 和 children 属性。children 属性是一个包含子分类的数组,子分类也具有相同的结构。我们的目标是编写一个 JavaScript 函数,该函数能够:

接收一个分类 ID 数组作为输入。如果提供了分类 ID 数组,则返回所有指定分类 ID 的子项,并将结果扁平化为一个数组。如果没有提供分类 ID 数组,则返回所有顶级分类及其直接子项。如果提供的分类 ID 没有子项,则返回一个空数组。避免使用 for、foreach 和 while 循环。

实现方法

我们可以使用递归和栈数据结构来实现这个功能,同时避免使用 for、foreach 和 while 循环。

代码示例(TypeScript)

立即学习“Java免费学习笔记(深入)”;

interface Category {  name: string;  id: string;  count: string;  depth: string;  children: Category[];}const mapCategory = (category: Category) => ({  name: category.name,  id: category.id,  count: category.count,});const getCategoriesChildren = (  categoryIds: Category['id'][],  categories: Category[],) => {  const foundChildren: Pick[] = [];  if (categoryIds.length === 0) {    return categories.reduce<Pick[]>(      (acc, category) => {        acc.push(mapCategory(category), ...category.children.map(mapCategory));        return acc;      },      [],    );  }  const stack: (Category & { isDesired?: boolean })[] = [...categories];  while (stack.length) {    const category = stack.pop();    if (!category) continue;    const isDesiredCategory =      categoryIds.includes(category.id) || category.isDesired;    if (isDesiredCategory) {      foundChildren.push(...category.children.map(mapCategory));    }    stack.push(      ...(isDesiredCategory        ? category.children.map((child) => ({ ...child, isDesired: true }))        : category.children),    );  }  return foundChildren;};// 示例数据const data: Category[] = [    {      name: "Car",      id: "19",      count: "20",      depth: "1",      children: [        {          name: "Wheel",          id: "22",          count: "3",          depth: "2",          children: [            {              name: "Engine",              id: "101",              count: "1",              depth: "3",              children: [                {                  name: "Engine and Brakes",                  id: "344",                  count: "1",                  depth: "4",                  children: []                }              ]            }          ]        }      ]    },    {      name: "Bike",      id: "3",      count: "12",      depth: "1",      children: [        {          name: "SpeedBike",          id: "4",          count: "12",          depth: "2",          children: []        }      ]    }  ];// 示例用法const categoryIds = ['22', '3'];const children = getCategoriesChildren(categoryIds, data);console.log(children);const noCategoryIds = [];const defaultChildren = getCategoriesChildren(noCategoryIds, data);console.log(defaultChildren);

代码解释:

Category 接口: 定义了分类对象的结构。mapCategory 函数: 用于从 Category 对象中提取 id、count 和 name 属性,创建一个新的对象。getCategoriesChildren 函数:接收一个分类 ID 数组 categoryIds 和一个分类数组 categories 作为输入。如果 categoryIds 为空,则返回所有顶级分类及其直接子项。如果 categoryIds 不为空,则使用栈数据结构来遍历分类树,找到所有指定分类 ID 的子项。stack 存储 categories 与附加的 isDesired?: boolean 属性,用于指示该 category 是否为指定 ID 的子代。如果 category 的 id 在 categoryIds 中,则将其 children 压入栈中,并设置 isDesired: true。当 category id 在 categoryIds 中或 category.isDesired 为 true 时,才将其 children 加入 foundChildren。示例数据和用法: 展示了如何使用 getCategoriesChildren 函数。

注意事项

此方法使用栈数据结构进行深度优先搜索,适用于深度嵌套的分类数据。代码使用 TypeScript 编写,可以轻松转换为 JavaScript。mapCategory 函数用于提取必要的属性,可以根据实际需求进行修改。可以根据需要修改代码以处理其他场景,例如处理循环引用或限制搜索深度。

总结

本文提供了一个使用 JavaScript 查找并扁平化特定分类 ID 的子项的教程。通过使用栈数据结构和递归,我们可以避免使用 for、foreach 和 while 循环,从而使代码更加简洁和易于理解。 此方法适用于处理深度嵌套的分类数据,并且可以根据实际需求进行修改。

以上就是使用 JavaScript 查找并扁平化特定分类 ID 的子项的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1517400.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 10:44:15
下一篇 2025年12月20日 10:44:28

相关推荐

  • JavaScript中的函数式编程组合子有哪些实用案例?

    函数式编程中的组合子通过纯函数组合提升代码质量。使用 pipe/compose 实现函数链式调用,如 sanitizeInput 对输入处理;柯里化生成可复用函数,如 whereEq 过滤用户角色;Maybe 避免空值判断,安全访问嵌套属性;Promise.all 协调异步并行,retry 增强请求…

    2025年12月20日
    000
  • 如何利用 Service Worker 实现可靠的离线应用和资源缓存?

    Service Worker 是实现 Web 应用离线可用的核心,通过注册并激活代理、缓存关键资源、拦截请求返回缓存内容,并在更新时清理旧缓存,确保离线体验稳定可靠。 要让 Web 应用在离线状态下依然可用,Service Worker 是核心工具。它充当浏览器与网络之间的代理,能拦截请求并返回缓存…

    2025年12月20日
    000
  • 如何利用 JavaScript 的 Service Worker 实现离线可用的 Web 应用?

    Service Worker通过拦截请求和缓存资源实现离线访问,需在HTTPS环境下注册sw.js文件;安装时预缓存核心资源,激活后采用缓存优先策略响应请求,并在版本更新时清理旧缓存,从而提升Web应用的离线可用性。 要让 Web 应用在离线状态下依然可用,Service Worker 是关键。它是…

    2025年12月20日
    000
  • 如何设计一个前端项目的架构决策记录?

    采用React函数组件与Hooks:已采纳,2023年决定。背景为类组件维护难、逻辑复用差;决策选用函数组件与Hooks;理由包括更优的逻辑封装、社区趋势、团队熟悉;影响涉及更新开发规范、培训成本;替代方案含类组件继承(复杂度高)和HOC(嵌套深)。 设计前端项目的架构决策记录(Architectu…

    2025年12月20日
    000
  • 从 TypeScript 数组中获取最后 N 个元素

    本文介绍了如何使用 TypeScript 从数组中提取最后 N 个元素。我们将讨论在数组长度满足特定条件时返回原数组,否则返回数组的后 N 个元素的方法,并提供代码示例和改进方案,帮助开发者更灵活地处理数组数据。 问题分析 原始代码存在一些问题: 逻辑错误: 使用 || (OR) 运算符判断数组长度…

    2025年12月20日
    000
  • 如何用Web Locks API管理资源并发访问?

    Web Locks API 是一种浏览器提供的机制,通过互斥锁协调同源下页面与 Worker 对共享资源的访问。它不锁定硬件资源,而是提供逻辑同步,确保关键代码串行执行,避免竞态条件。核心方法为 navigator.locks.request(lockName, options?, callback…

    2025年12月20日
    000
  • Angular DatePipe 完整指南:解决日期格式化常见问题

    本文详细介绍了如何在 Angular 应用中正确使用 DatePipe 进行日期格式化。通过导入 DatePipe 模块、在组件中提供并注入 DatePipe 实例,以及在 HTML 模板中应用管道,可以有效解决日期格式化不生效的问题。文章还提供了示例代码、输入数据类型建议和格式化参数等注意事项,帮…

    2025年12月20日
    000
  • Angular组件通信:孙子组件调用祖父组件方法的两种策略

    本文探讨Angular中孙子组件调用祖父组件方法的两种核心策略。首先,介绍如何通过@Output事件逐层向上触发,实现组件间的松散耦合通信,并分析其适用场景。其次,阐述利用共享服务(Service)直接注入到孙子组件,以实现更简洁、高效且易于维护的跨层级方法调用,并强调服务在状态管理和业务逻辑封装中…

    2025年12月20日
    000
  • 解决Flexbox六边形网格在窄屏溢出问题:响应式单位vw的应用

    针对Flexbox六边形网格在窄屏设备上出现内容溢出的问题,本教程将深入探讨vh单位在宽度定义上的局限性。核心解决方案是改用vw(视口宽度)单位来定义六边形元素的宽度和水平边距,确保网格能根据视口宽度进行自适应缩放,从而有效避免溢出,实现完美的响应式布局。 理解窄屏溢出问题 在构建响应式布局时,尤其…

    2025年12月20日
    000
  • React列表项点击事件处理与数据获取指南

    本教程旨在解决React应用中列表项点击事件的正确处理方式,以及如何在点击时获取并操作被点击项的数据。文章将详细阐述错误的事件绑定方式及其原因,并提供两种推荐的解决方案:使用匿名箭头函数和定义独立的事件处理函数,以确保组件能够响应用户交互并传递所需数据。 引言:React列表中点击事件的处理 在re…

    2025年12月20日
    000
  • TypeScript数组条件切片指南:高效获取最后N个元素及其边界处理

    本教程详细阐述了如何在TypeScript中根据数组长度进行条件切片,以高效地获取数组的最后N个元素。文章将介绍如何正确使用Array.prototype.slice()方法,处理数组长度的边界条件,并提供灵活可配置的解决方案,确保代码的健壮性和可读性。 在前端开发中,我们经常需要根据特定条件从数组…

    2025年12月20日
    000
  • React 列表项点击事件无法触发 active 状态切换的调试与解决方案

    本文旨在解决React列表项点击事件无法正确触发active状态切换的问题。通过分析常见错误原因,如混淆:active伪类和active类名,以及状态更新不正确等,提供清晰的解决方案和代码示例,帮助开发者快速定位并修复问题,实现预期的交互效果。文章将重点讲解如何正确使用状态管理和CSS样式,以确保列…

    2025年12月20日
    000
  • 解决React列表中onClick事件无法触发Active状态切换的问题

    本文旨在帮助开发者解决React列表中点击事件无法正确切换元素Active状态的问题。通过分析常见错误原因,例如混淆:active伪类和active类名,并提供清晰的代码示例和CSS样式,帮助读者理解并掌握正确实现Active状态切换的方法,从而提升用户交互体验。 在React中,实现列表项的点击激…

    2025年12月20日
    000
  • Angular DatePipe:在模板中正确格式化日期的教程

    本文详细介绍了如何在 Angular 应用中正确使用 DatePipe 来格式化日期。内容涵盖了 DatePipe 的导入、在组件中配置为提供者(provider)、通过依赖注入获取实例,以及在 HTML 模板中应用 DatePipe 的具体步骤和代码示例,旨在帮助开发者避免常见的日期格式化问题。 …

    2025年12月20日
    000
  • TypeScript中基于长度条件高效切片数组的实践指南

    本文旨在指导读者如何在TypeScript中根据数组长度进行条件性切片操作。我们将深入探讨常见的编程误区,如不当的数据传递和逻辑判断错误,并提供使用Array.prototype.slice()方法实现灵活、高效数组切片的专业解决方案,包括如何优化函数以支持动态切片数量,从而提升代码的健壮性和可复用…

    2025年12月20日
    000
  • 解决React列表点击事件无法触发Active状态切换的问题

    本文旨在解决React列表中点击事件无法正确触发元素Active状态切换的问题。通过分析常见的代码结构和CSS样式,我们将深入探讨如何正确地使用状态管理和CSS类名,以实现点击列表项时动态改变其样式的效果。本文将提供详细的代码示例和注意事项,帮助开发者避免常见的错误,并构建出交互性更强的用户界面。 …

    2025年12月20日
    000
  • 将扁平化JSON数据转换为多级嵌套结构:JavaScript实现指南

    本教程详细介绍了如何将包含层级信息的扁平化JSON数组转换为具有多级嵌套(subNav)结构的JSON对象。通过迭代处理数据并利用一个映射表追踪每个层级的最新节点,我们可以高效地构建出复杂的树形结构,从而实现数据的清晰组织和展示。 1. 理解问题:扁平化数据与目标结构 在前端开发或数据处理中,我们经…

    2025年12月20日
    000
  • 掌握 Angular DatePipe:日期格式化实战

    本文详细介绍了在 Angular 应用中正确使用 DatePipe 进行日期格式化的方法。我们将探讨 DatePipe 不生效的常见原因,并提供完整的解决方案,包括模块导入、组件提供器配置、依赖注入以及在模板中应用 DatePipe 的最佳实践,确保日期能够按照预期格式化显示。 在 angular …

    2025年12月20日
    000
  • JavaScript中的模块联邦(Module Federation)原理是什么?

    模块联邦通过 exposes 和 remotes 配置实现应用间模块共享,运行时动态加载 remoteEntry.js 并注册远程模块,结合 shared 机制避免依赖重复加载,适用于微前端架构下的独立部署与插件化集成。 模块联邦(Module Federation)是 Webpack 5 引入的一…

    2025年12月20日
    000
  • JavaScript中的模块联邦在微前端中如何应用?

    模块联邦通过运行时共享代码实现微前端高效集成。主应用配置remotes加载远程子应用,子应用用exposes暴露模块,shared确保依赖去重。例如主应用可直接导入userApp/UserList组件,实现跨应用调用。优势包括独立部署、技术栈共存、依赖共享,需注意版本统一与接口稳定。 模块联邦(Mo…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信