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

Posted SSXfont

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了10ReactJs基础知识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 元素以及函数。

以上是关于10ReactJs基础知识10--组件组合 vs 继承的主要内容,如果未能解决你的问题,请参考以下文章

ReactJS-2-props vs state

从 ReactJS 中的数组中删除复杂组件

将数据从一个组件访问到另一个组件

在 ReactJS 中使用 state 和 Function 组件时如何使输入不失去焦点?

reactjs-mobile常用组件

[React 基础系列] React 中的 元素 vs 组件