useimprerativeHandle的使用

请添加图片描述
这个钩子让我想起来了vue中的有一个自定义指令的钩子方法,有点类似,只是不同的是,react中是在单个组件内,在一些使用场景上会受限,但是也刚好满足所需,而在vue中它既有全局的,也有内部的。

使用示例:
父组件:

import ImperativeHandle from "./component/ImperativeHandle"
import React from 'react'
import { Button } from 'antd'

const Home: React.FC = (props, ref) => {
  console.log(ref)
  const buttonRef = React.useRef(null) 
  // 这里就可以获取到子组件中所暴露的钩子,从而实现控制子组件
  const buttonHandler = () => {
    console.log(buttonRef)
    buttonRef.current.focus()
  }
  return <>
    <div>
      <Button onClick={buttonHandler}>我是按钮</Button>
      // 子组件
      <ImperativeHandle ref={buttonRef} />
    </div>
  </>
}

export default Home

子组件:

import { forwardRef, useImperativeHandle, useRef } from "react";

function FancyInput(props, ref) {
  const inputRef = useRef();
  // 设置组件方法,在父组件内调用
  useImperativeHandle(ref, () => ({
    focus: () => {
      inputRef.current.focus();
    }
  }));
  return <input ref={inputRef} />;
}
//forwardRef这个方法就是将组件内设置的方法暴露给子组件
const ImperativeHandle = forwardRef(FancyInput);

export default ImperativeHandle
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值