当前位置: 首页 > article >正文

React【1】【ref常用法】

文章目录

  • 前言
  • 用途
    • 1. 储存
    • 2. 储存dom句柄ref


前言

react组件每次调用setState的时候都会重新执行函数组件或者class组件

用途

1. 储存

每次调用setState时,组件函数都会重新执行。下面这种情况点击提交后,再点击取消,会发现定时器trimId1仍然执行了。这是因为trimId1被重新赋值了。

function App() {
  const [msg, setMsg] = useState("未提交");

  let trimId1 = 0;
  const trimId2 = useRef(0);
  console.log("更新重新执行函数");

  const onAsyncSend = () => {
    trimId1 = setTimeout(() => {
      alert("发送1");
    }, 3000);

    trimId2.current = setTimeout(() => {
      alert("发送2");
    }, 3000);

    setMsg("等待提交");
  };

  const onCancel = () => {
    clearTimeout(trimId1);
    clearTimeout(trimId2.current);
  };

  return (
    <>
      <div>
        <button onClick={onAsyncSend}>提交</button>
        <button onClick={onCancel}>取消</button>
        <p>{msg}</p>
      </div>
    </>
  );
}


2. 储存dom句柄ref

import {useRef} from "react"
function com(){
	const refDom = useRef(0);

	return <><input ref={refDom}/></>
}

http://www.kler.cn/news/314835.html

相关文章:

  • 小程序地图展示poi帖子点击可跳转
  • 20240921在友善之臂的NanoPC-T6开发板上使用Rockchip原厂的Android12适配宸芯的数传模块CX6602N
  • 【监控】【Nginx】使用 ELK Stack 监控 Nginx
  • Docker Compose 启动 PostgreSQL 数据库
  • 《在华为交换机上配置防止 ARP 攻击》
  • 一个基于 Tauri、Vite 5、Vue 3 和 TypeScript 构建的即时通讯系统,牛啊牛啊!(附源码)
  • 无人机助力智慧农田除草新模式,基于YOLOv10全系列【n/s/m/b/l/x】参数模型开发构建无人机航拍场景下的农田杂草检测识别系统
  • 分布式变电站电力监控系统
  • EmptyDir-数据存储
  • gis专业怎么选电脑?
  • Elasticsearch 检索优化:停用词的应用
  • 【补充篇】Davinci工具要求的dbc格式
  • Springboot与minio
  • 【百日算法计划】:每日一题,见证成长(016)
  • [数据集][目标检测]文本表格检测数据集VOC+YOLO格式6688张5类别
  • 华为HarmonyOS地图服务 3 - 如何开启和展示“我的位置”?
  • 掌控历史:如何通过Git版本管理工具提升你的开发效率
  • 【记录一下VMware上开虚拟端口映射到公网】
  • 华为云centos7.9按装ambari 2.7.5 hostname 踩坑记录
  • SpringBoot中基于Mybatis-Plus多表联查(无xml,通过注解实现)
  • 车载软件调试工具系列---Trace32简介UI界面简介
  • C#基础(16)实践:学生成绩管理系统
  • 1.随机事件与概率
  • TCP: Textual-based Class-aware Prompt tuning for Visual-Language Model
  • 【学习笔记】STM32F407探索者HAL库开发(四)F103时钟系统配置
  • 等保测评与网络安全等级划分
  • 【网络通信基础与实践第三讲】传输层协议概述包括UDP协议和TCP协议
  • linux 基础(一)mkdir、ls、vi、ifconfig
  • 汽车EDI:MöllerTech EDI项目案例
  • 实战讲稿:Spring Boot整合MyBatis