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

react中使用ResizeObserver来观察元素的size变化

在 React 中使用 ResizeObserver 来观察元素的大小变化,可以通过创建一个自定义 Hook 来封装 ResizeObserver 的逻辑,并在组件中使用这个 Hook。以下是一个完整的示例,展示了如何在 React 中使用 ResizeObserver 来观察元素的大小变化。

自定义 Hook

首先,创建一个自定义 Hook 来封装 ResizeObserver 的逻辑:

import { useEffect, useRef, useState } from 'react';const useResizeObserver = () => {const [size, setSize] = useState({ width: 0, height: 0 });const elementRef = useRef(null);useEffect(() => {const resizeObserver = new ResizeObserver(entries => {for (let entry of entries) {setSize({width: entry.contentRect.width,height: entry.contentRect.height});}});if (elementRef.current) {resizeObserver.observe(elementRef.current);}return () => {if (elementRef.current) {resizeObserver.unobserve(elementRef.current);}resizeObserver.disconnect();};}, []);return [elementRef, size];
};export default useResizeObserver;

解释

  1. useResizeObserver Hook:创建一个自定义 Hook,返回一个 ref 和元素的大小。
  2. useState:用于存储元素的大小。
  3. useRef:用于引用要观察的元素。
  4. useEffect:在组件挂载时创建 ResizeObserver 实例,并在组件卸载时清理观察器。
  5. resizeObserver.observe:开始观察元素的大小变化。
  6. resizeObserver.unobserve 和 resizeObserver.disconnect:停止观察元素的大小变化并断开观察器。

使用自定义 Hook

在组件中使用这个自定义 Hook 来观察元素的大小变化:

import React from 'react';
import useResizeObserver from './useResizeObserver';const MyComponent = () => {const [elementRef, size] = useResizeObserver();return (<div><div ref={elementRef} style={{ width: '50%', height: '200px', backgroundColor: 'lightblue' }}>Resize me!</div><p>Width: {size.width}px</p><p>Height: {size.height}px</p></div>);
};export default MyComponent;

解释

  1. useResizeObserver Hook:在组件中调用自定义 Hook,获取 ref 和元素的大小。
  2. ref 属性:将 ref 赋值给要观察的元素。
  3. 显示元素的大小:在组件中显示元素的宽度和高度。
http://www.lryc.cn/news/508806.html

相关文章:

  • Linux快速入门-Linux文件系统管理
  • 漏洞检测工具:Swagger UI敏感信息泄露
  • VSCode如何修改默认扩展路径和用户文件夹目录到D盘
  • 【超详细实操内容】django的身份验证系统之限制用户访问的三种方式
  • AI芯片常见概念
  • Linux 中 epoll 的详解
  • 增加nginx配置文件(conf.d), 管理多个项目
  • PostgreSQL编译安装教程
  • 【提审】Android包提审报权限问题
  • xdoj 数字个数统计
  • 空天地遥感数据识别与计算--数据分析如何助力农林牧渔、城市发展、地质灾害监测等行业革新
  • Git:查看分支、创建分支、合并分支
  • 联合目标检测与图像分类提升数据不平衡场景下的准确率
  • Git的简介
  • 麒麟操作系统服务架构保姆级教程(四)NGINX中间件
  • Glide 自定义圆角、铺满FitXY
  • 蓝牙协议——音乐启停控制
  • Krita安装krita-ai-diffusion工具搭建comfyui报错没有ComfyUI_IPAdapter_plus解决办法
  • 四相机设计实现全向视觉感知的开源空中机器人无人机
  • LightGBM分类算法在医疗数据挖掘中的深度探索与应用创新(上)
  • JVM(Java虚拟机)的组成部分详解
  • jsp中的四个域对象(Spring MVC)
  • 计算机基础知识复习12.24
  • 如何使用vscode解决git冲突
  • 告别卡顿:CasaOS轻NAS设备安装Gopeed打造高效下载环境
  • Java 重写(Override)与重载(Overload)
  • HDFS与HBase有什么关系?
  • CentOS7下的vsftpd服务器和客户端
  • 全网最详细Gradio教程系列10——Blocks:底层区块类(下)
  • 嵌入式设备常用性能和内存调试指令