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 源码中可以看到实现了绑定以及清理的逻辑。

相关推荐
用户81686947472510 小时前
Chrome 插件开发入门
前端
_Eleven10 小时前
前端布局指南
前端·css
Gogo112111 小时前
JavaScript 里的“空”:Null 与 Undefined 的终极指南
javascript
一枚前端小姐姐11 小时前
Vue3 + Vite 从零搭建项目,超详细入门指南
前端·vue.js
赵_叶紫11 小时前
Docker 从入门到部署实战
前端
PD我是你的真爱粉11 小时前
Vue 3 生命周期完全指南:从流程图到最佳实践
前端·vue.js·流程图
耀耀切克闹灬11 小时前
前端签章数据的模板处理
前端
用户68026590511911 小时前
全栈可观测性白皮书——实施、收益与投资回报率
javascript·后端·面试
掘金安东尼11 小时前
⏰前端周刊第 454 期(2026年2月16日-2月22日)
前端·javascript·面试
掘金安东尼12 小时前
⏰前端周刊第 453 期(2026年2月9日-2月15日)
前端·javascript·面试