react 中的 createRef,createContext,forwardRef

createRef

react 即将抛弃 <div ref = 'myDiv' />这种 string ref的用法,将来只能使用俩种方式来使用 ref

class App extends React.Component{
	constructor(){
		this.ref = React.createRef()
	}
	render(){
		return <div ref = {this.ref} />
		//or
		return <div ref = {(node) => this.funRef = node} />
	}
}
createContext

createContext是官方定稿的 context 方案,老的context API都是 React 不推荐的 API,现在新的 API 释出。

const {Provider,Consumer} = React.createContext('defaultValue')
const ProviderComp = (props) => (
	<Provider value = {'realValue'}>
		{props.children}
	</Provider>
)
const ConsumerComp = () => (
	<Consumer>
		{(value) => <p>{value}</p>}
	<Consumer>
)
forwardRef

forwardRef是用来解决 HOC 组件传递 ref 的问题的,HOC 是 Higher Order Component,比如使用redux时,我们用connect来给组件绑定需要的state,这其中其实就是给我们的组件在外部包了一层组件,然后通过...props的方式把外部的props传入到实际组件。

const TargetComponent = React.forwardRef((props,ref) => {
	<TargetComponent ref={ref} />
})

这时候,如果使用string ref就没法当做参数传递了,所以提供createRef作为新的 ref 使用

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值