React@16.x(30)useImperativeHandle

目录

1,介绍

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

举例:

js 复制代码
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,使用

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

js 复制代码
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个参数中即可:

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

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


以上。

相关推荐
爱泡脚的鸡腿16 小时前
uni-app D4 实战(小兔鲜)
前端·vue.js·架构
星火飞码iFlyCode16 小时前
iFlyCode+SpecKit应用:照片等比智能压缩功能实现
前端·javascript
广白16 小时前
钉钉小程序直传文件到 阿里云OSS
前端·vue.js·uni-app
zyfts17 小时前
🔥告别 20 分钟等待!NestJS 生产级消息队列 BullMQ 实践指南
前端·后端
GISer_Jing17 小时前
3DThreeJS渲染核心架构深度解析
javascript·3d·架构·webgl
狗头大军之江苏分军17 小时前
【压力】一位一线炼钢工人的消失
前端·后端
拉不动的猪17 小时前
文件下载:后端配置、前端方式与进度监控
前端·javascript·浏览器
Amy_yang18 小时前
前端实现 Server-Sent Events 全解析:从代码到调试的实战指南
前端·uni-app
sean聊前端18 小时前
听说vite要一统江湖了,我看看怎么个事
前端
喝二两啤酒18 小时前
手把手打通 H5 多支付通道(Apple pay、Google pay、第三方卡支付)
前端