react18 实现具名插槽

简介: react18 实现具名插槽

效果预览

技术要点

父组件给子组件传递的 JSX 超过一个标签时,子组件接收到的 children 是一个数组,通过解析数组中各 JSX 的属性 slot ,即可实现具名插槽的分发!

代码实现

Father.jsx

import Child from "./Child";

export default function Father() {
  return (
    <div>
      <Child>
        <h2 slot="title">标题</h2>
        <p slot="content">内容</p>
      </Child>
    </div>
  );
}

Child.jsx

function Child({ children }) {
  let slotDic = {};
  if (Array.isArray(children)) {
    children.forEach((child) => {
      let slotName = child.props.slot;

      if (slotName) {
        slotDic[slotName] = child;
      }
    });
  }

  return (
    <div>
      <h1>子组件</h1>
      {slotDic.title}
      {slotDic.content}
    </div>
  );
}

export default Child;
目录
相关文章
|
3月前
|
前端开发 JavaScript 开发者
react18【系列实用教程】组件 (2024最新版 | 含父子组件传值、兄弟组件传值、越层组件传值、“插槽“)
react18【系列实用教程】组件 (2024最新版 | 含父子组件传值、兄弟组件传值、越层组件传值、“插槽“)
45 2
|
前端开发 JavaScript
react-05-slot-插槽
slot 插槽 在 vue里就常用 react的插槽其实也一样 还是模拟一个消息框 类似 elemetui 或者 iview message组件的形式
239 0
react-05-slot-插槽
|
2月前
|
前端开发 JavaScript UED
React 基础与实践 | 青训营笔记
React 基础与实践 | 青训营笔记
44 0
|
3月前
|
前端开发 JavaScript Java
React 速通笔记
【7月更文挑战第17天】
41 1
|
前端开发
前端学习笔记202305学习笔记第二十九天-React keep alive原理之2
前端学习笔记202305学习笔记第二十九天-React keep alive原理之2
72 0
|
前端开发
前端学习笔记202306学习笔记第四十八天-react-admin marmelab之8
前端学习笔记202306学习笔记第四十八天-react-admin marmelab之7
48 0
|
5月前
|
前端开发 JavaScript
前端知识笔记(二十六)———React如何像Vue一样将css和js写在同一文件
前端知识笔记(二十六)———React如何像Vue一样将css和js写在同一文件
60 1
|
11月前
|
前端开发
前端笔记:React的form表单全部置空或者某个操作框置空的做法
在React框架前端开发中,经常会有弹出框的开发,涉及到弹出框,难免就会有表单。一般在关闭弹出框或者对表单联动时,往往都需要考虑对表单进行置空操作了。
87 0
|
Web App开发 前端开发 JavaScript
前端学习笔记202307学习笔记第五十七天-模拟面试笔记react-fiber解决了什么问题
前端学习笔记202307学习笔记第五十七天-模拟面试笔记react-fiber解决了什么问题
67 0
|
JavaScript 前端开发 调度
前端学习笔记202307学习笔记第五十七天-模拟面试笔记react-fiber和虚拟dom关系
前端学习笔记202307学习笔记第五十七天-模拟面试笔记react-fiber和虚拟dom关系
106 0

热门文章

最新文章

下一篇
无影云桌面