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 元素以及函数。