10、ReactJs基础知识10--组件组合 vs 继承

1、 组件使用一个特殊的 children prop 来将他们的子组件传递到自己的渲染结果中:
       这使得别的组件可以通过 JSX 嵌套,将任意组件作为子组件传递给它们
      function FancyBorder(props) {
        return (
          <div className={'FancyBorder FancyBorder-' + props.color}>
            {props.children}
          </div>
        );
      }

      function WelcomeDialog() {
        return (
          <FancyBorder color="blue">
            <h1 className="Dialog-title">
              Welcome
            </h1>
            <p className="Dialog-message">
              Thank you for visiting our spacecraft!
            </p>
          </FancyBorder>
        );
      }
你可能需要在一个组件中预留出几个“洞”。
这种情况下,我们可以不使用 children,而是自行约定:将所需内容传入 props,并使用相应的 prop,即可以给子组件命名
function SplitPane(props) {
        return (
          <div className="SplitPane">
            <div className="SplitPane-left">
              {props.left}
            </div>
            <div className="SplitPane-right">
              {props.right}
            </div>
          </div>
        );
      }
      function Contacts(props){
        return <h1>联系人</h1>;
      }
      function Chat(props){
        return <h1>聊天室</h1>;
      }

      function App() {
        return (
          <SplitPane
            left={
              <Contacts />
            }
            right={
              <Chat />
            } />
        );
      }
 <Contacts /> 和 <Chat /> 之类的 React 元素本质就是对象(object),
 所以你可以把它们当作 props,像其他数据一样传递。这种方法可能使你想起别的库中“槽”(slot)的概念,
 但在 React 中没有“槽”这一概念的限制,你可以将任何东西作为 props 进行传递
 此处相当于vue中的具名插槽
 
2、特例关系
    有些时候,我们会把一些组件看作是其他组件的特殊实例,比如 WelcomeDialog 可以说是 Dialog 的特殊实例。
    在 React 中,我们也可以通过组合来实现这一点。“特殊”组件可以通过 props 定制并渲染“一般”组件:
    相当于给函数传递实参返回结果一样
function Dialog(props) {
        return (
          <FancyBorder color="blue">
            <h1 className="Dialog-title">
              {props.title}
            </h1>
            <p className="Dialog-message">
              {props.message}
            </p>
          </FancyBorder>
        );
      }

      function WelcomeDialog() {
        return (
          <Dialog
            title="Welcome"
            message="Thank you for visiting our spacecraft!" />

        );
      }
3、组合也同样适用于以 class 形式定义的组件。
Props 和组合为你提供了清晰而安全地定制组件外观和行为的灵活方式。
 注意:组件可以接受任意 props,包括基本数据类型,React 元素以及函数。
posted @ 2020-02-10 21:41  极客小乌龟  阅读(261)  评论(0编辑  收藏  举报