继续拓展前面的例子,现在我们已经有了 Header 组件了。假设我们现在构建一个新的组件叫 Title,它专门负责显示标题。你可以在 Header 里面使用 Title组件:

  1. class Title extends Component {
  2. render () {
  3. return (
  4. <h1>React 小书</h1>
  5. )
  6. }
  7. }
  8. class Header extends Component {
  9. render () {
  10. return (
  11. <div>
  12. <Title />
  13. </div>
  14. )
  15. }
  16. }

我们可以直接在 Header 标签里面直接使用 Title 标签。就像是一个普通的标签一样。React.js 会在 <Title /> 所在的地方把 Title 组件的 render 方法表示的 JSX 内容渲染出来,也就是说 <h1>React 小书</h1> 会显示在相应的位置上。如果现在我们在 Header 里面使用三个 <Title /> ,那么就会有三个 <h1 /> 显示在页面上。

  1. <div>
  2. <Title />
  3. <Title />
  4. <Title />
  5. </div>

这样可复用性非常强,我们可以把组件的内容封装好,然后灵活在使用在任何组件内。另外这里要注意的是,自定义的组件都必须要用大写字母开头,普通的 HTML 标签都用小写字母开头

现在让组件多起来。我们来构建额外的组件来构建页面,假设页面是由 HeaderMainFooter 几个部分组成,由一个 Index 把它们组合起来。

  1. import React, { Component } from 'react';
  2. import ReactDOM from 'react-dom';
  3. class Title extends Component {
  4. render () {
  5. return (
  6. <h1>React 小书</h1>
  7. )
  8. }
  9. }
  10. class Header extends Component {
  11. render () {
  12. return (
  13. <div>
  14. <Title />
  15. <h2>This is Header</h2>
  16. </div>
  17. )
  18. }
  19. }
  20. class Main extends Component {
  21. render () {
  22. return (
  23. <div>
  24. <h2>This is main content</h2>
  25. </div>
  26. )
  27. }
  28. }
  29. class Footer extends Component {
  30. render () {
  31. return (
  32. <div>
  33. <h2>This is footer</h2>
  34. </div>
  35. )
  36. }
  37. }
  38. class Index extends Component {
  39. render () {
  40. return (
  41. <div>
  42. <Header />
  43. <Main />
  44. <Footer />
  45. </div>
  46. )
  47. }
  48. }
  49. ReactDOM.render(
  50. <Index />,
  51. document.getElementById('root')
  52. )

最后页面会显示内容:

React.js 小书组件嵌套

组件可以和组件组合在一起,组件内部可以使用别的组件。就像普通的 HTML 标签一样使用就可以。这样的组合嵌套,最后构成一个所谓的组件树,就正如上面的例子那样,Index 用了 HeaderMainFooterHeader 又使用了 Title 。这样用这样的树状结构表示它们之间的关系:

React.js 小书组件嵌套

这里的结构还是比较简单,因为我们的页面结构并不复杂。当页面结构复杂起来,有许多不同的组件嵌套组合的话,组件树会相当的复杂和庞大。理解组件树的概念对后面理解数据是如何在组件树内自上往下流动过程很重要。

课后练习


因为第三方评论工具有问题,对本章节有任何疑问的朋友可以移步到 React.js 小书的论坛 发帖,我会回答大家的疑问。