[react+ts] useRef获取自定义组件dom或方法声明
想用useRef获取自定义组件?
如果获取dom,直接写
const sonRef = useRef<HTMLDivElement>(null);
然后子组件用forwardRef包一层,注意是HTMLDivElement,别写错, 写HTMLElement不行
const Son = forwardRef<HTMLDivElement, IProps>((props, ref) => {})
切记这时Son不能写Son:React.FC了,不然报错

这时候可以打印dom了

那怎么拿子组件的方法呢? 先把 forwardRef第一个参数改为ref的类型

定义暴露的函数
const handleClick = () => {setNum(8999);};useImperativeHandle(ref, () => {return {handleClick,};});
父组件也要改一下

这时候点一下就出来了

我直接打印sonRef.current试试

ok
相关文章:
[react+ts] useRef获取自定义组件dom或方法声明
想用useRef获取自定义组件? 如果获取dom,直接写 const sonRef useRef<HTMLDivElement>(null); 然后子组件用forwardRef包一层,注意是HTMLDivElement,别写错, 写HTMLElement不行 const Son forwardRef<HTMLDivElement, IProps>((props, ref) > {}) 切记这…...
AI 将在今年获得“永久记忆”,2028美国会耗尽能源储备
AI的“永久记忆”时代即将来临 谷歌前CEO施密特揭示了AI技术的前景,他相信即将在2025年迎来一场伟大的变化。AI将实现“永久记忆”,改变我们与科技的互动过程。施密特将现有的AI上下文窗口比作人类的短期记忆,难以持久保存信息。他的设想是…...
【视频笔记】基于PyTorch从零构建多模态(视觉)大模型 by Umar Jamil【持续更新】
视频链接: 基于PyTorch从零构建多模态(视觉)大模型 by Umar Jamil 从头编写一个视觉语言模型:PloyGamma,是谷歌的一个模型 1:原始图像 2:视觉编码器(本文是viT),通过对比学习进行训练。这个对比学习最开始是CLIP,后来被谷歌改成了SigLIP 3:线性投影层 4:如何将图…...
解决 C++ 中头文件相互引用和解耦问题
在 C 中,当多个 .h 文件相互引用时,可能会导致 循环依赖 或 头文件冗余 问题,进而引发编译时间延迟、代码复杂度增加等问题。为了有效地解耦和组织代码,可以采用以下几种策略和思想: 1. 前向声明(Forward …...
河马剧场(短剧)APP的邀请码怎么填写
上篇给大家说到河马剧场免费看短剧还能领5.2元3天vip会员,本文就说一下河马剧场河马短剧APP的邀请码怎么填写。 河马短剧APP填写邀请码分三步: 1、安装登陆河马短剧APP 2、点击底部导航栏中间的“福利” 3、往下划会看到“填写邀请码领3天vip” 4、…...
01:C语言的本质
C语言的本质 1、ARM架构与汇编2、局部变量初始化与空间分配2.1、局部变量的初始化2.1、局部变量数组初始化 3、全局变量/静态变量初始化化与空间分配4、堆空间 1、ARM架构与汇编 ARM简要架构如下:CPU,ARM(能读能写),Flash(能读&a…...
第1章:数据库基础
第1章:数据库基础 1.1 数据库概述 1.1.1 什么是数据库 数据库的定义数据库的发展历程数据库的重要性 1.1.2 关系型数据库简介 关系型数据库模型常见的关系型数据库关系型数据库的特点 1.1.3 MySQL在企业中的应用 Web应用电商平台金融系统大数据存储 1.2 数据…...
C++教程 | string类的定义和初始化方法
在C中,string是标准库中用于处理字符串的类,定义在 头文件中,它提供了方便、灵活的字符串操作功能。以下是一些常见的定义和初始化string对象的方法: 1. 默认初始化 可以直接定义一个空的string对象,语法如下&#x…...
React中的合成事件
合成事件与原生事件 区别: 1. 命名不一样,原生用纯小写方式,react用小驼峰的方式 原生:onclick React的:onClick 2. 事件处理函数的写法不一样 原生的是传入一个字符串,react写法传入一个回调函数 3.…...
[SMARTFORMS] 创建FORM
输入事务码SMARTFORMS进入表单开发界面,选中表单,自定义表单名称ZFS_DEMO_2025 点击"创建"按钮,跳转至"SAP表格设计器"页面 在"表格属性"填写表单描述、指定页格式和样式 在"表格接口"可以填写SMART…...
成都和力九垠科技有限公司九垠赢系统Common存在任意文件上传漏洞
免责声明: 本文旨在提供有关特定漏洞的深入信息,帮助用户充分了解潜在的安全风险。发布此信息的目的在于提升网络安全意识和推动技术进步,未经授权访问系统、网络或应用程序,可能会导致法律责任或严重后果。因此,作者不对读者基于本文内容所采取的任何行为承担责任。读者在…...
基于Python的考研学习系统
作者:计算机学姐 开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等,“文末源码”。 专栏推荐:前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏:…...
『SQLite』几种向表中插入数据的方法
向表中插入数据 INSERT INTO 语句用来给数据库中的某个表中新增数据行。 案例 直接根据基本语法插入数据插入时不用全部指定列名方式根据查询结果将数据插入另一张表中 注意 上述内容详讲见文章:SQLite的INSERT操作(内含案例)...
什么是Kafka的重平衡机制?
Kafka 的重平衛机制是指在消费者组中新增或删除消费者时,Kafka 集群会重新分配主题分区给各个消费者,以保证每个消费者消费的分区数量尽可能均衡。 重平衡机制的目的是实现消费者的负载均衡和高可用性,以确保每个消费者都能够按照预期的方式…...
pdf预览 报:Failed to load module script
pdf 预览报: Failed to load module script: Expected a JavaScript module script but the server responded with a MIME type of “application/octet-stream”. Strict MIME type checking is enforced for module scripts per HTML spec. 报错原因:…...
AI 角色扮演法的深度剖析与实践
📢📢📢 大家好,我是云楼Yunlord,CSDN博客之星人工智能领域前三名,多年人工智能学习工作经验,一位兴趣稀奇古怪的【人工智能领域博主】!!!😜&#…...
weblogic问题
安装weblogic单机后启动weblogic进程: 第一行: 这是一个 su 命令,用于切换到 weblogic 用户。 第二行: 这是 weblogic 用户的 bash shell 会话。 第三行: 这是启动 WebLogic 服务器的脚本。 第四行: 这是 …...
Qt仿音乐播放器:客户端唯一化
一、铺垫 1.我们采用共享内存来进行客户端的唯一化; 2.我刚看到的时候,就感觉,这是人想出来的吗?太绝了 二、实例 int main(int argc, char *argv[]) {QApplication a(argc, argv);QSharedMemory shareMemory("Widget&qu…...
ceph文件系统
ceph文件系统:高度可扩展,分布式的存储文件系统,旨在提高性能,高可靠性和高可用的对 象存储,块存储,文件系统的存储。使用分布式的算法保证数据的高可用和一致性。 ceph的组件 1、MON:ceph m…...
【数据结构-堆】力扣2530. 执行 K 次操作后的最大分数
给你一个下标从 0 开始的整数数组 nums 和一个整数 k 。你的 起始分数 为 0 。 在一步 操作 中: 选出一个满足 0 < i < nums.length 的下标 i , 将你的 分数 增加 nums[i] ,并且 将 nums[i] 替换为 ceil(nums[i] / 3) 。 返回在 恰好…...
别再只测准确率!智能代码生成必须评估的4个隐藏可维护性指标(附IEEE Std. 2914-2024合规对照表)
第一章:智能代码生成代码可维护性评估的范式跃迁 2026奇点智能技术大会(https://ml-summit.org) 传统代码可维护性评估长期依赖人工审查、圈复杂度(Cyclomatic Complexity)或静态指标(如注释率、函数长度),…...
SpringBoot 声明式事务与编程式事务
上一篇我们详细讲解了 Transactional 注解的用法、原理和失效场景,其实 Transactional 属于「声明式事务」,是 SpringBoot 中最常用的事务管理方式。但很多开发者不知道,SpringBoot 还支持另一种事务管理方式——「编程式事务」。实际开发中&…...
AI代码配额=新型IT预算?2026奇点大会披露:头部企业已将配额消耗纳入DevOps成本中心KPI(含真实财务映射表)
第一章:2026奇点智能技术大会:AI代码配额管理 2026奇点智能技术大会(https://ml-summit.org) 配额管理的核心挑战 随着大模型驱动的AI编程工具在企业级开发流程中深度集成,未经约束的自动代码生成正引发资源过载、安全策略失焦与合规审计失…...
FileLocator Pro进阶搜索:从布尔逻辑到正则表达式的实战指南
1. 为什么需要掌握FileLocator Pro的进阶搜索技巧 作为一个常年和各类文档、日志打交道的IT从业者,我深知在海量文件中寻找特定信息有多痛苦。记得有一次,客户服务器突然报错,我需要从几十GB的日志文件中找出特定错误码和关联的请求ID。当时…...
告别玄学调试:用逻辑分析仪和Python脚本深度验证AD7124的SPI与寄存器
从波形分析到自动化验证:AD7124寄存器调试的工程化实践 调试精密ADC芯片从来不是简单的"通电-读取"过程。当我在一个高精度温度测量项目中首次接触AD7124时,那些看似随机的寄存器写入失败、飘忽不定的转换结果和难以复现的异常状态࿰…...
020、总结与实战项目:手把手打造你的个性化语音助手
上周调试语音唤醒模块,半夜被一段合成音频吓得不轻——本该说“早上好”的TTS,硬生生念成了“造上好”,每个字都像用刀切出来的,机械感十足。那一刻我意识到,很多开发者把TTS当成黑盒调用,直到实际产品落地时才被发音质量、延迟、资源占用等问题打得措手不及。今天我们就…...
用Python脚本解放双手:Epson V370扫描仪批量处理老照片实战
Python自动化扫描:Epson V370老照片数字化全攻略 每次翻看泛黄的老照片时,你是否想过把这些珍贵的记忆永久保存下来?但面对堆积如山的相册,手动一张张扫描又让人望而却步。作为一名经历过这个痛苦过程的开发者,我想分享…...
HWIOAuthBundle性能优化:大规模用户认证的5个最佳实践
HWIOAuthBundle性能优化:大规模用户认证的5个最佳实践 【免费下载链接】HWIOAuthBundle OAuth client integration for Symfony. Supports both OAuth1.0a and OAuth2. 项目地址: https://gitcode.com/gh_mirrors/hw/HWIOAuthBundle HWIOAuthBundle作为Symfo…...
STM32 Flash Timeout 报错全解析:从芯片锁死到安全烧录的实战指南
1. 当KEIL突然弹窗:Flash Timeout背后的故事 那天下午三点,我正在给新版的STM32F103烧录程序,KEIL突然弹出那个熟悉的红色警告框:"Flash Timeout. Reset the Target and try it again"。这个场景估计每个STM32开发者都…...
Proteus 8.13 保姆级教程:从零开始用Arduino UNO模板创建你的第一个仿真项目
Proteus 8.13 零基础实战指南:Arduino UNO仿真项目全流程解析 引言:为什么选择Proteus进行Arduino仿真? 对于电子设计爱好者而言,硬件投入成本常常成为学习路上的第一道门槛。一块Arduino UNO开发板虽然价格亲民,但当需…...
