cnzhuanyong 2023-08-18 07:57 采纳率: 38.9%
浏览 4
已结题

如何检测 react children 数组中,每个元素的类型?

网上没查出答案。


 const childrens = Children.toArray(children);

  Children.forEach(childrens, (child, index) => {
    // 如何判断是否是 MenuItem,是否是 MenuItemCheckbox,和子菜单 MenuList
    if(child.){}
    // 之后我要( child.props.icon && setHasIcon(true);)
  });
  • 写回答

1条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2023-08-18 10:13
    关注

    【以下回答由 GPT 生成】

    问题:如何检测 React children 数组中每个元素的类型,并执行相关操作?

    如果你想要检测 React 的 children 数组中每个元素的类型,并根据类型执行相关操作,可以借助 React 的元素类型判断方法和条件语句来实现。

    在给出具体代码示例之前,以下是一种可能的解决方案:

    import React, { Children, isValidElement } from 'react';
    
    const Menu = ({ children }) => {
      const [hasIcon, setHasIcon] = useState(false);
    
      const childrenArray = Children.toArray(children);
    
      childrenArray.forEach((child, index) => {
        if (isValidElement(child)) {
          if (child.type === MenuItem) {
            // 如果是 MenuItem 类型
            setHasIcon(child.props.icon ? true : false);
          } else if (child.type === MenuItemCheckbox) {
            // 如果是 MenuItemCheckbox 类型
            setHasIcon(child.props.icon ? true : false);
          } else if (child.type === MenuList) {
            // 如果是 MenuList 类型
          }
        }
      });
    
      return (
        <div>
          {hasIcon ? <span>有图标</span> : <span>无图标</span>}
          {children}
        </div>
      );
    };
    
    const MenuItem = ({ children, icon }) => {
      return (
        <div>
          {icon && <span>{icon}</span>}
          {children}
        </div>
      );
    };
    
    const MenuItemCheckbox = ({ children, icon }) => {
      return (
        <div>
          {icon && <span>{icon}</span>}
          {children}
        </div>
      );
    };
    
    const MenuList = ({ children }) => {
      return <div>{children}</div>;
    };
    

    在上面的代码中,我们首先使用Children.toArray()将 children 转换为数组,然后使用forEach()遍历每个子元素。在遍历过程中,我们使用isValidElement()来检查是否是一个有效的 React 元素。然后,我们使用条件语句判断每个子元素的类型,并执行相应的操作。

    在这个例子中,我们判断了三种类型:MenuItem、MenuItemCheckbox 和 MenuList。如果是 MenuItem 或 MenuItemCheckbox 类型,我们通过child.props.icon判断是否有图标,并根据结果设置hasIcon的状态值。如果是 MenuList 类型,我们可以根据需求进行特定操作。

    最后,在 Menu 组件中,我们根据hasIcon状态值展示有无图标的信息,并将 children 渲染出来。

    请注意,以上仅是一个示例,具体的解决方案可能会根据你的具体需求而有所不同。你可以根据自己的情况进行修改和扩展。

    希望以上回答对你有帮助!如果有任何疑问,请随时提问。



    【相关推荐】



    如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 8月19日
  • 已采纳回答 8月19日
  • 创建了问题 8月18日

悬赏问题

  • ¥15 基于卷积神经网络的声纹识别
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 stm32开发clion时遇到的编译问题