React中的插槽

一、react插槽

1.1 代码演示

使用this.props.children
新建children.js组件,写入:

import React, { Component } from 'react'

class Child extends Component {
    render() {
        return (
            <div>
                children
                {this.props.children[0]}
                {this.props.children[1]}
                {this.props.children[2]}

            </div>
        )
    }
}

export default class Children extends Component {
  render() {
    return (
      <div>
          <Child>
              <div>11111</div>
              <div>22222</div>
              <div>33333</div>

          </Child>
      </div>
    )
  }
}

效果:
在这里插入图片描述


1.2 插槽好处

为了复用,一定程度减少父子通信。
例如之前点击显示隐藏的功能,代码修改如下:

import React, { Component } from 'react'

class Navbar extends Component {
  render() {
    return (
      <div style={{background: "red"}}>
          {this.props.children}
          <span>navbar</span>
      </div>
    )
  }
}

class Sidebar extends Component {
    render() {
      return (
        <div style={{background: "green", width: "100px"}}>
            <ul>
                <li>1111</li>
                <li>1111</li>
                <li>1111</li>
                <li>1111</li>
                <li>1111</li>
            </ul>
        </div>
      )
    }
  }

export default class Children extends Component {
  state = {
      isShow: false
  }  
  
  render() {
    return (
      <div>
          <Navbar>
              <button onClick={() => {
                  this.setState({
                      isShow: !this.state.isShow
                  })
              }}>click</button>
          </Navbar>
          {this.state.isShow && <Sidebar></Sidebar>}
      </div>
    )
  }
}

效果:
在这里插入图片描述
在这里插入图片描述

可以看到直接将按钮写在了子组件的插槽了,可以直接访问父组件的状态,设置隐藏显示,而不用通过父子通信,但是这个只能在一定程度上减少,不能把组件里所有的逻辑都写在插槽里,插槽的功能最大的用处还是在于复用。

在学习React的路上,如果你觉得本文对你有所帮助的话,那就请关注点赞评论三连吧,谢谢,你的肯定是我写博的另一个支持。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
React 插槽抽屉是一种常见的 UI 组件,用于在页面上创建一个可以展开或折叠的侧边栏或底部面板。它通常用于显示额外的内容,例如菜单、设置选项或通知。 在 React 实现插槽抽屉可以通过以下步骤: 1. 创建一个 React 组件来表示抽屉,并在组件的状态跟踪抽屉的展开/折叠状态。 2. 在组件的渲染方法,根据抽屉的状态决定是否渲染抽屉内容。可以使用条件渲染或 CSS 类控制显示/隐藏样式。 3. 在页面的其他部分添加一个触发器,例如按钮或链接,用于切换抽屉的展开/折叠状态。这个触发器可以调用组件的一个方法来更新状态。 下面是一个简单的示例代码,展示了如何实现一个基本的插槽抽屉: ```jsx import React, { useState } from "react"; const Drawer = () => { const [isOpen, setIsOpen] = useState(false); const toggleDrawer = () => { setIsOpen(!isOpen); }; return ( <div> <button onClick={toggleDrawer}>Toggle Drawer</button> {isOpen && <div className="drawer-content">Drawer Content</div>} </div> ); }; export default Drawer; ``` 在上面的代码,`isOpen` 状态用于跟踪抽屉的展开/折叠状态。当点击按钮时,`toggleDrawer` 方法会更新 `isOpen` 状态的值,从而控制抽屉的显示与隐藏。根据 `isOpen` 的值,决定是否渲染抽屉内容。 你可以根据自己的需求来扩展这个示例,并添加适当的样式和动画效果。希望这个示例对你有帮助!如果需要更多的信息或代码示例,请随时提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你华还是你华

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值