React实现一个支持动态插槽的Layout组件
目录
目标实现一个支持动态注册内容的插槽组件,思路:提供一个 Context,维护插槽中注册的内容,并将其渲染到对应的位置。
思路
- 采用
Context
实现插槽的注册和管理,并提供对应的渲染。 - 采用
自定义Hook
将往插槽注册内容逻辑抽离封装 - 提供对应的渲染器将插槽内容挂载到React组件树上
代码实现
一、定义 Context
import React, { createContext, useState } from "react"; export const SlotContext = createContext({ slots: { header: [], footer: [], }, registerSlot: (name: "header" | "footer", content: React.ReactNode) => undefined, }); const SlotProvider: React.FC<{ children: React.ReactNode }> = ({ children, }) => { const [slots, setSlots] = useState<{ header: React.ReactNode[]; footer: React.ReactNode[]; }>({ header: [], footer: [], }); // 定义注册函数 const register = (name: "header" | "footer", content: React.ReactNode) => { setSlots((pre) => { const newValue = { ...pre }; if (newValue[name]) { newValue[name] = [content]; return newValue; } else { return pre; } }); }; return ({children} ); };
二、封装 useSlotRegister 自定义 Hook
export function useSlotRegister( name: "header" | "footer", content: React.ReactNode ) { const { registerSlot } = React.useContext(SlotContext); React.useEffect(() => { registerSlot(name, content); // 清除 return () => { registerSlot(name, null); }; }, [name, content]); }
三、将插槽内的注册的内容渲染到 React 组件树上
渲染器可以根据自定义处理内容进行处理,如果您想让插槽注册的内容按照优先级进行排序,修改注册的内容(标记优先级),渲染器中使用优先级字段进行排序然后渲染。以下只是一个简单的渲染实现:
// export const HeaderSlotRenderer: React.FC = () => { const { slots } = React.useContext(SlotContext); return <>{slots.header}>; }; export const FooterSlotRenderer = () => { const { slots } = React.useContext(SlotContext); return <>{slots.footer}>; }; export const Layout: React.FC<{ children: React.ReactNode }> = ({ children, }) => { return ({/* render header */} ); }; {children}
/* src/components/Layout.css */ .layout { display: flex; flex-direction: column; min-height: 100vh; } .header { height: 100px; background-color: #333; color: white; display: flex; align-items: center; justify-content: center; } .main { flex: 1; background-color: #f4f4f4; padding: 20px; } .footer { height: 80px; background-color: #333; color: white; display: flex; align-items: center; justify-content: center; }
挂载
import ReactDOM from "react-dom/client"; import { Layout, SlotContext, useSlotRegister } from "./Layout"; const rootElement = document.getElementById("root")!; const root = ReactDOM.createRoot(rootElement); const HeaderTitle = () => { const { registerSlot } = React.useContext(SlotContext); // 手动 Register registerSlot( "header",); return null; }; const FooterDate = () => { // use hook Register useSlotRegister("footer",Header
@2025); return null; }; root.render(); Layout... main
到此这篇关于React实现一个支持动态插槽的Layout组件的文章就介绍到这了,更多相关React动态插槽组件内容请搜索科站长以前的文章或继续浏览下面的相关文章希望大家以后多多支持科站长!
栏 目:JavaScript
本文地址:https://www.fushidao.cc/wangluobiancheng/3147.html
您可能感兴趣的文章
- 02-11js中基本事件的总结(onclick、onblur、onchange等)
- 02-11详解如何在Node.js中使用中间件处理请求
- 02-11Vue3中Provide和Inject的用法及工作原理详解
- 02-11Vue+vant实现图片上传添加水印
- 02-11快速解决 keep-alive 缓存组件中定时器干扰问题
- 02-11uniapp 使用 tree.js 解决模型加载不出来的问题及解决方法
- 02-11基于uniapp vue3 的滑动抢单组件实例代码
- 02-10JavaScript 中的 Map使用指南
- 02-10vue3中使用print-js组件实现打印操作步骤
- 02-10Vue 中v-model的完整用法及v-model的实现原理解析


阅读排行
推荐教程
- 04-23JavaScript Array实例方法flat的实现
- 04-23THREE.JS使用TransformControls对模型拖拽的代码实例
- 04-23Vue3使用v-if指令进行条件渲染的实例代码
- 04-23vue3+ts项目搭建的实现示例
- 04-23JavaScript实现下载超大文件的方法详解
- 04-23vue如何使用pdf.js实现在线查看pdf文件功能
- 04-23vue.js调用python脚本并给脚本传数据
- 12-18使用JavaScript遍历输出页面中的所有元素的方法详解
- 04-23JS加密解密之保存到桌面书签
- 12-18Vue实现滚动加载更多效果的示例代码