【Vue】vue3 中使用 ResizeObserver 监听元素的尺寸宽度变化

news/2024/11/15 5:38:24/

要监听 div 宽度的变化,可以使用 ResizeObserver 接口。ResizeObserver 允许你观察一个或多个元素的尺寸变化,并在发生变化时执行回调函数。这种方法比使用 MutationObserver 更专注于尺寸变化,且不受元素属性变化的影响。

使用 ResizeObserver

首先,创建一个 ResizeObserver 实例,并传入一个回调函数,该函数将在元素尺寸变化时被调用。在回调函数中,你可以访问每个观察到的元素的新尺寸。

javascript">const resizeObserver = new ResizeObserver(entries => {entries.forEach(entry => {const { width, height } = entry.contentRect;console.log(`Element resized: Width=${width}, Height=${height}`);});
});// 假设你想观察的元素是一个具有特定ID的div
const observedElement = document.querySelector('#yourDivId');// 开始观察该元素
resizeObserver.observe(observedElement);// 当需要停止观察时,可以调用 disconnect 方法
// resizeObserver.disconnect();

在 vue3 中的使用

const container = ref(null);
let observer;
let resizeTimer;onMounted(() => {createObserver();
});onUnmounted(() => {if (observer) {observer.disconnect();}
});function createObserver() {observer = new ResizeObserver((entries) => {clearTimeout(resizeTimer);resizeTimer = setTimeout(() => {for (const entry of entries) {const { width, height } = entry.contentRect;console.log(width);}}, 200);});observer.observe(container.value);
}
<div ref="container"></div>

注意事项

  • ResizeObserver 是现代浏览器支持的 API,不是所有浏览器都支持。请确保你的目标浏览器支持此 API,或者使用 polyfill 来提供跨浏览器兼容性。
  • ResizeObserver 只能观察到元素的尺寸变化,不能检测到元素的内容变化或内部布局变化。
  • 如果你需要在元素的内容或布局变化时也触发事件,可能需要结合使用其他技术,如 MutationObserver

http://www.ppmy.cn/news/1505444.html

相关文章

时间同步--- ntp与ptp

时间同步 1. 什么是NTP时间&#xff1f;什么是PTP时间&#xff1f; NTP时间&#xff08;Network Time Protocol 时间&#xff09;: NTP即网络时间协议&#xff08;Network Time Protocol&#xff09;&#xff0c;它是一种用于同步计算机时间的网络协议。NTP可以将所有参与的计…

TypeScript循环

循环 循环 一直重复的做某一件事 循环需要的必须条件&#xff1a;1.开始条件 2.结束条件3.变量的更新 while循环允许程序在满足特定条件时重复执行一段代码块&#xff0c;直到条件不再满足为止 结构&#xff1a;while(条件表达式){ //需要重复执行的代码块 } let a:numb…

3款热门剪辑软件,打工人如何在2024年提升效率?

在现在这个快得飞起的工作节奏下&#xff0c;提高效率成了咱们每个打工人的必修课。特别是在视频剪辑这一块&#xff0c;不管是自媒体的创作者还是公司的宣传人员&#xff0c;都得找些给力的工具来帮忙。今天我们就来聊聊几款流行的剪辑软件&#xff0c;看看它们怎么帮我们在20…

开发一个MutatingWebhook

介绍 Webhook就是一种HTTP回调&#xff0c;用于在某种情况下执行某些动作&#xff0c;Webhook不是K8S独有的&#xff0c;很多场景下都可以进行Webhook&#xff0c;比如在提交完代码后调用一个Webhook自动构建docker镜像 准入 Webhook 是一种用于接收准入请求并对其进行处理的…

哪些系统需要按照等保2.0进行定级?

等保2.0适用的系统类型 根据等保2.0的要求&#xff0c;需要进行定级的系统主要包括但不限于以下几类&#xff1a; 基础信息网络&#xff1a;包括互联网、内部网络、虚拟专用网络等。云计算平台/系统&#xff1a;涵盖公有云、私有云、混合云等多种部署模式的云服务平台。大数据…

桌面云备份可以删除吗?安不安全

桌面云备份可以删除吗&#xff1f;答案是可以的。如果用户不需要这些备份或者想要释放存储空间&#xff0c;桌面云备份是可以进行删除的&#xff0c;并且删除桌面云备份是一个相对安全的过程&#xff0c;但需要注意以下几点来确保操作的安全性和数据的完整性。 一、桌面云备份…

无人机长生不老秘籍

机身保养 外观检查 1.检查机器表面整洁无划痕无针孔凹陷擦伤、畸变等损坏情况 2.晃动机身&#xff0c;仔细听机身内部有无松动零件或者螺丝在机身内部 桨叶检查 1.有无裂痕、磨损、变形等缺陷&#xff0c;如有明显缺陷建议更换 2.卡扣、紧固件有无松脱或失效&#xff0c;…

【区块链+医疗健康】区块链 + 医保病历审核服务平台 | FISCO BCOS应用案例

中共中央国务院 2020 年的《关于深化医疗保障制度改革的意见》提出高起点推进标准化和信息化建设&#xff0c;统一医 疗保障业务标准和技术标准&#xff0c;建立全国统一、高效、兼容、便捷、安全的医疗保障信息系统&#xff0c;实现全国医疗保障 信息互联互通&#xff0c;加强…