React useImperativeHandle Hook

useImperativeHandle Hook 是一个比较比较简单的 hook,为 ref 节点添加一些处理方法,下面是来自官网例子,为 ref 添加了两个方法。

复制代码
import { forwardRef, useRef, useImperativeHandle } from 'react';

const MyInput = forwardRef(function MyInput(props, ref) {
  const inputRef = useRef(null);

  useImperativeHandle(ref, () => {
    return {
      focus() {
        inputRef.current.focus();
      },
      scrollIntoView() {
        inputRef.current.scrollIntoView();
      },
    };
  }, []);

  return <input {...props} ref={inputRef} />;
});

export default MyInput;

React 框架中对应的代码实现,代码实现比较简单,在绑定阶段mountImperativeHandle 方法中调用

返回值绑定在 ref.current 属性上,最后返回一个清理 ref.current 的方法。

总结

useImperativeHandle 在 React 为我提供了一个可以为 ref 绑定处理方法的 hook,useImperativeHandle 源码中可以看到实现了绑定以及清理的逻辑。

相关推荐
霪霖笙箫几秒前
「JS全栈AI Agent学习」六、当AI遇到矛盾,该自己决定还是问你?—— Human-in-the-Loop
前端·面试·agent
煜bart2 分钟前
使用 TypeScript 实现算法处理
开发语言·前端·javascript
光影少年6 分钟前
如何实现RN应用的离线功能、数据缓存策略?
react native·react.js·掘金·金石计划
Mike_jia14 分钟前
NginxPulse:Nginx日志监控革命!实时洞察Web流量与安全态势的智能利器
前端
风之舞_yjf19 分钟前
Vue基础(31)_插件(plugins)、scoped样式
前端·vue.js
M ? A27 分钟前
Vue3+TS实战避坑指南
前端·vue.js·经验分享
Mintopia33 分钟前
你以为是技术问题,其实是流程问题:工程效率的真相
前端
Mintopia39 分钟前
一套能落地的"防 Bug"习惯:不用加班也能少出错
前端
亿元程序员41 分钟前
箭头游戏那么火,搞个3D的可以吗?我:这不是3年前的游戏了吗?
前端
IT_陈寒42 分钟前
SpringBoot里的这个坑差点让我加班到天亮
前端·人工智能·后端