React 高阶组件(HOC)

React 高阶组件(HOC)

高阶组件不是 React API 的一部分,而是一种用来复用组件逻辑而衍生出来的一种技术。

什么是高阶组件

高阶组件就是一个函数,且该函数接受一个组件作为参数,并返回一个新的组件。基本上,这是从 React 的组成性质派生的一种模式,我们称它们为"纯"组件, 因为它们可以接受任何动态提供的子组件,但它们不会修改或复制其输入组件的任何行为。

简言之, 高阶组件:

  • 是一个函数
  • 传入一个组件
  • 返回一个新组件

Example: 给任意组件添加 Tooltip

这里通过一个例子演示高阶组件的用法。

  1. 高阶组件核心代码
javascript 复制代码
export const withTooltip = (Component: React.FunctionComponent) => {
  return ({ ...props }: any) => {
    return (
      <Flex gap={1}>
        <Component {...props} />
        <Tooltip description="这是提示内容">
          <IconPark type="info" />
        </Tooltip>
      </Flex>
    )
  }
}
  1. 传入需要添加 Tooltip 的组件
javascript 复制代码
const TypographyWithToolTip = withTooltip(Typography)
  1. 使用上一步返回的高阶组件
javascript 复制代码
<TypographyWithToolTip>111</TypographyWithToolTip>

效果展示:

相关推荐
俺不会敲代码啊啊啊2 分钟前
封装 ECharts Hook 适配多种图表容器
前端·vue.js·typescript·echarts
J2虾虾6 分钟前
在Vue3中推荐使用的函数定义方法
前端·javascript·vue.js
辻戋10 分钟前
从零手写mini-react
javascript·react.js·ecmascript
3秒一个大13 分钟前
Cookie/Session vs JWT 双 Token:登录认证方案的演进与对比
前端·安全·ajax
努力的lpp15 分钟前
【小迪安全41天】WEB攻防-ASP应用&HTTP.SYS&短文件&文件解析&Access注入&数据库泄漏
前端·安全·http
yellowbuff17 分钟前
巧用IntersectionObserver 与 Suspense,实现真正的视口内懒加载(vue3)
前端
A923A17 分钟前
【从零开始学 React | 第一章】React 基础与 JSX 核心语法
前端·react.js·前端框架·jsx
农夫山泉不太甜18 分钟前
package.json 字段详解:Node.js 项目的核心配置文件完全指南
前端
Melrose18 分钟前
移动端安全攻防
android·前端·安全
大萝卜呼呼19 分钟前
Next.js第八课 - 缓存机制
前端·next.js