React@16.x(30)useImperativeHandle

1,介绍

介绍 ref 时提到,ref 不能作用于函数组件,所以有了 ref 转发

举例:

function Child(props, ref) {
    return <h1 ref={ref}>child</h1>;
}

const ChildWrap = React.forwardRef(Child);

export default function App() {
    const refChild = useRef();
    return (
        <>
            <ChildWrap ref={refChild}></ChildWrap>
            <button
                onClick={() => {
                    console.log(refChild.current);
                }}
            >
                获取Child组件
            </button>
        </>
    );
}

useImperativeHandle 的作用:在 ref 转发的前提下,为了更方便的在函数组件中使用 ref

2,使用

其他代码不变,只对子组件做如下修改:

function Child(props, ref) {
    useImperativeHandle(
        ref,
        () => {
            return 123; // 相当于 ref.current = 123
        },
        []
    );
    // 此时 h1 上的 ref 失效。
    return <h1 ref={ref}>child</h1>;
}

同样的,依赖项不变,该HOOK的回调函数不会再次执行。

此时在父组件中获取的 refChild.current 就是 123。
所以如果想通过父组件调用子组件的一些方法,可以将这些方法放到 useImperativeHandle 的第2个参数中即可:

function Child(props, ref) {
    useImperativeHandle(
        ref,
        () => {
            return {
                method1() {
                    console.log("method1");
                },
                method2() {
                    console.log("method2");
                },
            };
        },
        []
    );
    return <h1>child</h1>;
}

父组件调用:refChild.current.method1()


以上。

相关推荐

  1. React@16.x30useImperativeHandle

    2024-06-16 07:40:04       11 阅读
  2. React@16.x31)useLayoutEffect

    2024-06-16 07:40:04       9 阅读
  3. react hook: useimperativeHandle

    2024-06-16 07:40:04       25 阅读
  4. React hooks - forwardRef+useImperativeHandle

    2024-06-16 07:40:04       11 阅读
  5. React@16.x(23)useEffect

    2024-06-16 07:40:04       15 阅读
  6. React@16.x(26)useContext

    2024-06-16 07:40:04       11 阅读
  7. React@16.x(27)useCallBack

    2024-06-16 07:40:04       9 阅读
  8. React@16.x(28)useMemo

    2024-06-16 07:40:04       9 阅读
  9. React@16.x(25)useReducer

    2024-06-16 07:40:04       12 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-16 07:40:04       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-16 07:40:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-16 07:40:04       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-16 07:40:04       20 阅读

热门阅读

  1. Web前端开发素材:探索、选择与应用的艺术

    2024-06-16 07:40:04       11 阅读
  2. Ubuntu修改MySQL的tmpdir参数失败的解决方法

    2024-06-16 07:40:04       11 阅读
  3. 两个矩阵差异分析

    2024-06-16 07:40:04       6 阅读
  4. Django ORM非空判断、以及通用写法

    2024-06-16 07:40:04       10 阅读
  5. 数据库面试

    2024-06-16 07:40:04       7 阅读
  6. MySQL的高可用方案:深入Galera Cluster和ProxySQL

    2024-06-16 07:40:04       10 阅读
  7. c++ 单例模式

    2024-06-16 07:40:04       6 阅读
  8. Elasticsearch机器学习初探:智能数据洞察

    2024-06-16 07:40:04       6 阅读