React.js 小书 Lesson22 - props.children 和容器类组件

有一类组件,充当了容器的做用,它定义了一种外层结构形式,而后你能够往里面塞任意的内容。这种结构在实际当中很是常见,例如这种带卡片组件:javascript

React.js 小书容器组件图片

组件自己是一个不带任何内容的方形的容器,我能够在用这个组件的时候给它传入任意内容:java

React.js 小书容器组件图片

基于咱们目前的知识储备,能够迅速写出这样的代码:react

class Card extends Component { render () { return ( <div className='card'> <div className='card-content'> {this.props.content} </div> </div> ) } } ReactDOM.render( <Card content={ <div> <h2>React.js 小书</h2> <div>开源、免费、专业、简单</div> 订阅:<input /> </div> } />, document.getElementById('root') ) 

咱们经过给 Card 组件传入一个 content 属性,这个属性能够传入任意的 JSX 结构。而后在 Card 内部会经过 {this.props.content} 把内容渲染到页面上。git

这样明显太丑了,若是 Card 除了 content 之外还能传入其余属性的话,那么这些 JSX 和其余属性就会混在一块儿。很很差维护,若是能像下面的代码那样使用 Card 那想必也是极好的:github

ReactDOM.render(
  <Card> <h2>React.js 小书</h2> <div>开源、免费、专业、简单</div> 订阅:<input /> </Card>, document.getElementById('root') ) 

若是组件标签也能像普通的 HTML 标签那样编写内嵌的结构,那么就方便不少了。实际上,React.js 默认就支持这种写法,全部嵌套在组件中的 JSX 结构均可以在组件内部经过 props.children 获取到:数组

class Card extends Component { render () { return ( <div className='card'> <div className='card-content'> {this.props.children} </div> </div> ) } } 

把 props.children 打印出来,你能够看到它实际上是个数组:less

React.js 小书容器组件图片

React.js 就是把咱们嵌套的 JSX 元素一个个都放到数组当中,而后经过 props.children 传给了 Cardide

因为 JSX 会把插入表达式里面数组中的 JSX 一个个罗列下来显示。因此其实就至关于在 Card 中嵌套了什么 JSX 结构,都会显示在 Card 的类名为 card-content 的 div元素当中。工具

这种嵌套的内容成为了 props.children 数组的机制使得咱们编写组件变得很是的灵活,咱们甚至能够在组件内部把数组中的 JSX 元素安置在不一样的地方:布局

class Layout extends Component { render () { return ( <div className='two-cols-layout'> <div className='sidebar'> {this.props.children[0]} </div> <div className='main'> {this.props.children[1]} </div> </div> ) } } 

这是一个两列布局组件,嵌套的 JSX 的第一个结构会成为侧边栏,第二个结构会成为内容栏,其他的结构都会被忽略。这样经过这个布局组件,就能够在各个地方高度复用咱们的布局。

总结

使用自定义组件的时候,能够在其中嵌套 JSX 结构。嵌套的结构在组件内部均可以经过 props.children 获取到,这种组件编写方式在编写容器类型的组件当中很是有用。而在实际的 React.js 项目当中,咱们几乎天天都须要用这种方式来编写组件。

课后练习

*黑色边框的容器组件


由于第三方评论工具备问题,对本章节有任何疑问的朋友能够移步到 React.js 小书的论坛 发帖,我会回答你们的疑问。

相关文章
相关标签/搜索