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",
Header
);
return null;
};
const FooterDate = () => {
// use hook Register
useSlotRegister("footer", @2025);
return null;
};
root.render(
Layout... main
);
到此这篇关于React实现一个支持动态插槽的Layout组件的文章就介绍到这了,更多相关React动态插槽组件内容请搜索科站长以前的文章或继续浏览下面的相关文章希望大家以后多多支持科站长!
栏 目:JavaScript
本文地址:https://zz.feitang.co/wangluobiancheng/3147.html
您可能感兴趣的文章
- 07-25如何使用 Deepseek 写的uniapp油耗计算器
- 07-25JavaScript其他类型的值转换为布尔值的规则详解
- 07-25JavaScript实现给浮点数添加千分位逗号的多种方法
- 07-25ReactNative环境搭建的教程
- 07-25JavaScript获取和操作时间戳的用法详解
- 07-25通过Vue实现Excel文件的上传和预览功能
- 07-25Node使用Puppeteer监听并打印网页的接口请求
- 07-25在Node.js中设置响应的MIME类型的代码详解
- 07-25Vue3解决Mockjs引入后并访问404(Not Found) 的页面报错问题
- 07-25如何利用SpringBoot与Vue3构建前后端分离项目


阅读排行
推荐教程
- 04-23JavaScript Array实例方法flat的实现
- 04-23Vue3使用v-if指令进行条件渲染的实例代码
- 04-23THREE.JS使用TransformControls对模型拖拽的代码实例
- 07-21JavaScript判断数据类型的四种方式总结
- 07-22JavaScript随机数生成各种技巧及实例代码
- 07-21JavaScript检查变量类型的常用方法
- 07-21基于vue3与supabase系统认证机制详解
- 04-23vue3+ts项目搭建的实现示例
- 07-21JavaScript双问号操作符(??)的惊人用法总结大全
- 07-22使用Node.js实现GitHub登录功能





