11 Component Composition

组件组合

React有着十分强大的组合模式, 用以实现组件间代码的重用
组件间关系决定着组件之前的组合关系

包含关系

对于例如侧边栏(Sidebar), 对话框(Dialog)这种通用容器来说,我们无法提前知晓其子组件的具体内容
1. 使用特殊的prop: children prop来把子组件传递到渲染结果中去。

function Sidebar(props) {
  return (
    <div style={{color: props.color}}>
      {props.children}
    </div>
  )
}

function Layout(props) {
  return (
    <div>
      <Sidebar color="red">
        <h1>Sidebar title</h1>
        <p>Navigation links here...</p>
        <AnotherComponent />
      </Sidebar>
    </div>
  )
}

2. 将组件通过props传递给父组件

  • 组件等React元素本质上就是对象,因此完全可以作为props传递
  • 这给你一种Vue中插槽(Slot)的感觉,但React中不存在插槽这一限制
  • 你可以将任何东西作为props传递
function Pane(props) {
  return (
    <div className="pane">
      <div className="left-pane">{props.left}</div>
      <div className="right-pane">{props.right}</div>
    </div>
  )
}

function App() {
  return (
    <Pane left={<Chat />} right={<Contact />} />
  )
}

特例关系

  • 所谓特例关系,即组件B是组件A的特例形式 通过对A进行封装实现B
  • 类似于B是A类的实例化,通过props(构造函数)进行封装(实例)
// 抽象组件A
function Dialog(props) {
  return (
    <FancyBorder color="blue">
      <h1>{props.title}</h1>
      <p>{props.message}</p>
    </FancyBorder>
  )
}
// 具化组件B
function WelcomeDialog() {
  return (
    <Dialog
      title="Welcome"
      message="Thank your for focusing!" />
  )
}

那继承呢?

没有继承!一切都可以用组合实现,不需要继承!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值