React Hooks useCallback理解

个人理解记录,如有错误 欢迎指出

在react函数式组件中定义函数 如:

export default props => {

	const handle = () => {
		console.log(11111)
	}
	
	return (
		<button onClick={handle}>点击</button>
	)
}

每次组件重新渲染,函数handle都会重新声明,使用useCallback后会缓存函数

export default props => {

	const handle = useCallback(() => {
		console.log(11111)
	}, [])
	
	return (
		<button onClick={handle}>点击</button>
	)
}

只会在useCallback的依赖变更后才会重新声明

但并不是所有的函数都需要useCallback,因为useCallback本身就存在性能开销,如果仅仅只是缓存函数是不必要的

下面是一个使用示例

const Child = ({ onClick }) => {
	return (
		<button onClick={onClick}>点击</button>
	)
}

export default props => {
	const [ value, setValue ] = useState(0)
	const handle = useCallback(() => {
		console.log(11111)
	}, [])
	const addValue = () => {
		setValue(value+1)
	}
	return (
		<div>
			<Child onClick={ handle } />
			<div>{ value }</div>
			<button onClick={ addValue }>点击</button>
		</div>
	)
}

在上面的示例中,如果没有使用useCallback缓存handle函数,那么每次在调用addValue函数改变value时,handle函数都会被重新声明,传给Child子组件的 onClick 都会是一个全新的函数从而导致Child组件被重新渲染,但这是不必要的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值