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

相关推荐
程序员ys几秒前
网页白屏的原理与优化
前端·性能优化·浏览器
@PHARAOH10 分钟前
WHAT - SWC Rust-based platform for the Web
开发语言·前端·rust
滕青山10 分钟前
HTML编码/解码 核心JS实现
前端·javascript·vue.js
dustcell.12 分钟前
企业级web应用服务器
前端
RunsenLIu25 分钟前
智慧房屋租赁管理系统
前端·javascript·vue.js
凌云拓界25 分钟前
TypeWell全攻略(四):AI键位分析,让数据开口说话
前端·人工智能·后端·python·ai·交互
明月_清风25 分钟前
pwa 安装/离线/推送/后台同步 全套高级能力
前端·pwa
cyber_两只龙宝28 分钟前
Tomcat--企业级web应用服务器详细介绍与整合Nginx配置流程
linux·运维·前端·nginx·云原生·tomcat·负载均衡