React 高阶组件

本文介绍了React高阶组件的概念,它是一个接收组件并返回新组件的函数。文中通过实例展示了如何使用高阶组件进行状态抽取和prop操纵,包括使用decorator语法糖和直接调用的方式,帮助提升组件的复用性和灵活性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

高阶组件:高阶组件就是一个接收一个组件并返回另外一个新组件的函数!

高阶组件总共分为两大类
一、代理方式( 1 、操纵 prop 2 、抽取状态 3 、包装组件)
1 、操纵 prop
增加 prop
import React from 'react' 
const HocAddProp = (WrappedComponent,uid) => 
    class extends React.Component {
         render() { 
            const newProps = { uid, 
          };
        return <WrappedComponent {...this.props} {...newProps} /> 
    } 
}
export default HocAddProp;
删除 prop

两个高阶组件的使用方法:

 

或者利用decorator语法糖,这样使用

2、抽取状态

将所有的状态的管理交给外面的容器组件,这个模式就是 抽取状态
外面的容器就是这个高阶组件

 

这样当我们在使用这个已经被包裹的 input 组件( SampleComponent )时候,它的值就被放在了 HocContainer 高 阶组件中,当很多这样的input 组件都用这个 HocContainer 高阶组件时,那么它们的值都将保存在这个HocContainer高阶组件中
3 、包装组件

 

这样使用

 

-- 代理方式的生命周期的过程类似于堆栈调用 :

代理方式下 WrappedComponent 会经历一个完整的生命周期,产生的新组件和参数组件是两个不同的组件,一次渲染,两个组件都会经历各自的生命周期。
二、继承方式( 1 、操纵生命周期 ( 渲染劫持 ) 2 、操纵 prop
-- 继承方式的生命周期的过程类似队列调用 :

 

在继承方式下,产生的新组件和参数组件合二为一, super.render 只是生命周期中的函数,变成一个生命周期。

 

这个例子很简单,相当于把WrappedComponent组件的render方法, 通过super.render()方法吐到了MyContainer 中,可以顺序调用。

1 、操纵生命周期 ( 渲染劫持 )
首先创建一个高阶,再创建一个使用高阶组件的组件,也就是是输入组件,最后再改变这个输入组件 props

 

这个高阶组件会直接读取输入组件中的 props,state, 然后控制了输入组件的 render 展示

 

然后调用,递减 time 数值直到变为 0 最后页面的效果就是,当然他不是循环的。先展示 我是一个组件 ,我设置了两秒,之后展示” 倒计时完成
由此可以看出高阶组件也可以控制 state
但是最好要限制这样做,可能会让 WrappedComponent 组件内部状态变得一团糟。建议可以通过重新命名 state , 以防止混淆。

 

2、操纵prop

这样就传入了新的props

克隆并返回一个新的 ReactElement ,新返回的元素会保留有旧元素的 props ref key ,也会集成新的 props
还有一个方式,在传递 props 上有着强于高阶组件的优势不用关心命名,

 

使用方式

 

感觉很方便,但是每次渲染都会重新定义一个新的函数,如果不想的话就不要定义匿名函数,

 

showUid(argument) { 
    return <div>{argument}</div> 
}

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值