• React 中,children 属性


    React 中,children 属性是一个特殊的属性,它允许你将组件作为其他组件的子元素传递。这意味着你可以在组件内部嵌套任何类型的子组件或元素,并且在父组件中通过 props.children 访问它们。这为组件的复用和组合提供了极大的灵活性。

    以下是 children 属性的一些常见用途:

    1. 内容分发:
      你可以使用 children 属性在组件之间传递 JSX 元素,这样父组件可以决定子组件的位置和渲染方式。

      const Card = ({ children }) => {
        return 
      {children}
      ; }; // 使用方式

      这是标题

      这是卡片的内容。

      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9

      在这个例子中,

      标签作为 Card 组件的子元素传递,并在 Card 组件内部通过 children 渲染。

    2. 创建布局组件:
      children 属性可以用来创建通用的布局组件,这些组件定义了页面的结构,但内容可以灵活变化。

      const Layout = ({ children }) => {
        return (
          
      这是页头
      {children}
      这是页脚
      ); }; // 使用方式
      这是主要内容。
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14
    3. 构建高阶组件(HOC):
      高阶组件可以接收一个组件并返回一个新组件,经常会使用 children 将元素传递给被包装的组件。

      const withExtraInfo = (WrappedComponent) => {
        return (props) => (
          
            

      这是额外的信息

      {props.children}
      ); };
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
    4. 渲染回调(Render Props):
      使用 children 作为函数,可以将动态的值或状态作为参数传递给子组件,这是所谓的渲染回调模式。

      const MouseTracker = ({ children }) => {
        const [mousePosition, setMousePosition] = useState({ x: 0, y: 0 });
      
        // ...更新鼠标位置的逻辑
      
        return children(mousePosition);
      };
      
      // 使用方式
      
        {({ x, y }) => (
          

      鼠标位置:{x}, {y}

      )}
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14

    children 属性的灵活性是 React 组件模型的核心特性之一,它允许开发者通过组合和嵌套的方式来构建复杂的 UI 结构。

  • 相关阅读:
    ARM体系结构与编程(更)
    走进人工智能|自动驾驶 开启智能出行新时代
    开发模型>螺旋模型
    【五天时间】Qt从入门到实战:第三天
    STM32F103VET6基于STM32CubeMX创建EXTI外部中断工程
    泡泡玛特,难成“迪士尼”
    ZXing - barcode scanning library for Java, Android
    机器学习-4
    axios的post请求所有传参方式
    MCU的环形FIFO
  • 原文地址:https://blog.csdn.net/qq_42391246/article/details/136343025