react ref 用法案例(支持ts提示)

复制代码
// 子组件
import React, { useEffect, useImperativeHandle } from "react";
  export interface DynamicFormRef {
    xxxx:()=>void;
  }
const Index = (props: ChooseDocumentProps, ref: React.MutableRefObject<DynamicFormRef> ) => {
// ...

    const [
        {
          showModal,
        },
        setState,
      ] = useImmer<ChooseDocumentState>({
        showModal: false
      });


    // ...

  const xxxx = ()=>{
}
useImperativeHandle(ref, () => ({ setVisible(status:boolean) { setState(st => { st.showModal = status; }) },
    xxxx }));
// ... } export default React.forwardRef(Index);
复制代码

 

复制代码
// 父组件调用子组件

// ...

const ChooseDocumentRef = useRef<DynamicFormRef>();
// ...

ChooseDocumentRef?.current?.setVisible(true);

// ...

<ChooseDocument ref={ChooseDocumentRef}/>
复制代码

 

参考:Hooks 的 useImperativeHandle 怎么用? - 简书 (jianshu.com) 

 

posted @   最好的年纪  阅读(149)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
历史上的今天:
2018-05-09 MVC与MVVM
2018-05-09 js正则删除字符串中的部分内容(支持变量和特殊符号)
2018-05-09 小程序之rpx适配方案
2018-05-09 表单元素内容禁用拼写检查
点击右上角即可分享
微信分享提示