😄
xlzy520
  • README
  • 执笔
    • 2017
      • 01 网站动态标题的两种方式
      • 02 RN App 外部唤醒踩坑记
    • 2018
      • 01 图片加解密二三事
      • 02 优雅实现 BackTop
      • 03 Vue 一键导出 PDF
      • 04 不一样の烟火
      • 05 Python 之禅
      • 06 Python 文件操作
    • 2019
      • 01 Aurora 食用指南
      • 02 Godaddy 域名找回记事
      • 03 一个接口的诞生
      • 04 SpringMVC 前后端传参协调
      • 05 主题集成友链访问统计功能
      • 06 Github Style 博客主题
      • 07 动态加载 JS 文件
      • 08 WebSocket 心跳重连机制
      • 09 洗牌算法实现数组乱序
      • 10 React Hook 定时器
      • 11 Fetch data with React Hooks
      • 12 字符编码の小常识
      • 13 WSL 安装 Docker 实录
      • 14 Eriri comic reader
  • 书斋
    • ES6 标准入门
      • 01 变量声明与解构赋值
      • 02 语法的扩展
      • 03 数据类型与数据结构
      • 04 Proxy 和 Reflect
      • 05 异步编程 Promise
      • 06 Iterator 和 for of 循环
      • 07 Generator 函数
      • 08 Async 函数
      • 09 Class 类
    • JavaScript 设计模式
      • 01 基础知识
      • 02 设计模式(上)
      • 03 设计模式(下)
      • 04 设计原则和编程技巧
  • 前端
    • JavaScript
      • 01 JavaScript 秘密花园
      • 02 JavaScript 正则技巧
      • 03 从浏览器解析 JS 运行机制
      • 04 Canvas 基础用法
      • 05 Flex 弹性布局
      • 06 Blob Url And Data Url
      • 07 函数节流与函数防抖
      • 08 排序算法初探
    • Node
      • 01 Node Tips
      • 02 七天学会 NodeJS
    • Note
      • 01 Note
      • 02 Snippets
      • 03 Interview
      • 04 Git
      • 05 Docker
      • 06 Line
    • React
      • 01 React Props Children 传值
      • 02 Use a Render Prop!
      • 03 React Hook
      • 04 React 和 Vue 中 key 的作用
    • Vue
      • 01 Vue Tips
      • 02 Vue 构建项目写入配置文件
      • 03 Vue 项目引入 SVG 图标
  • 后端
    • Java
      • 01 浅析 Java 反射
      • 02 Java 服务端分层模型
    • Note
      • 01 Note
      • 02 Linux
      • 03 MySQL
    • Spring
      • 01 Spring Boot
      • 02 Spring Data
      • 03 JPA
      • 04 Swagger
      • 05 AOP
      • 06 SSM
    • Project
      • 01 微信点餐系统
由 GitBook 提供支持
在本页
  • props.children 属性
  • props.children 传值
  • 多层传值

这有帮助吗?

  1. 前端
  2. React

01 React Props Children 传值

背景是在使用 umijs 框架时,它提供一个根节点 layout。我想在根节点传值到 Route 组件中却不得其法,后来查阅 issues 得到解答。

props.children 属性

在 React 中 props.children 是一个特殊的存在,它表示该组件的所有节点。组件中 props.children 的值存在三种可能性:

  • 如果当前组件没有子节点,值类型为 undefined

  • 如果当前组件只有一个子节点,值类型为 object

  • 如果当前组件有多个子节点,值类型为 array

在 umijs 中,layout 根节点也是通过 props.children 来引用 Route 页面组件,所以在给 Route 传值时遇到了盲点。

props.children 传值

在一般的 React 组件中,可以很方便的通过 props 传值,但是在 props.children 中如何实现传值呢,也就是怎么样在父组件中对不确定的子组件进行 props 传递呢?

React 提供一个工具方法 React.Children 来处理 props.children。它提供一些有用的方法来处理 props.children:

  • React.Children.map:用来遍历子节点,而不用担心 props.children 的数据类型是 undefined 还是 object。

  • React.Children.forEach:同 React.Children.map,用来遍历子节点,但不返回对象。

  • React.Children.count:返回 children 当中的组件总数,和传递给 map 或者 forEach 的回调函数的调用次数一致。

  • React.Children.only:返回 children 中仅有的子级,否则抛出异常。

同时 React 提供 React.cloneElement 方法用来克隆并返回一个新的 ReactElement(内部子元素也会跟着克隆),新返回的元素会保留有旧元素的 props、ref、key,也会集成新的 props。

我们将上面两者配合就能实现 props.children 传值:

const App = props => {
  const childrenWithProps = React.Children.map(props.children, child => {
    return React.cloneElement(child, { test: 'test' })
  })
  return <>{childrenWithProps}</>
}

多层传值

在 umijs 中,Layout 与 Route 组件之间隔了两层,所以在 Layout 里传值的话需要 clone 两级,因为第一级是 Switch,然后才是 Route。

React.Children.map(children, child => {
  return React.cloneElement(
    child,
    null,
    React.Children.map(child.props.children, child => {
      return React.cloneElement(child, { test: 'test' })
    })
  )
})
上一页React下一页02 Use a Render Prop!

最后更新于5年前

这有帮助吗?

参考文章:

support pass props from layouts to child routes