Vue3使用ResizeObserver监听元素的尺寸宽度变化
要监听 div
宽度的变化,可以使用 ResizeObserver
接口。ResizeObserver
允许你观察一个或多个元素的尺寸变化,并在发生变化时执行回调函数。这种方法比使用 MutationObserver
更专注于尺寸变化,且不受元素属性变化的影响。
使用 ResizeObserver
首先,创建一个 ResizeObserver
实例,并传入一个回调函数,该函数将在元素尺寸变化时被调用。在回调函数中,你可以访问每个观察到的元素的新尺寸。
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
。
到此这篇关于Vue3使用ResizeObserver监听元素的尺寸宽度变化的文章就介绍到这了,更多相关Vue3 ResizeObserver监听宽度变化内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Vue中金额、日期格式化插件@formatjs/intl的使用及说明
这篇文章主要介绍了Vue中金额、日期格式化插件@formatjs/intl的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-02-02vuex 多模块时 模块内部的mutation和action的调用方式
这篇文章主要介绍了vuex 多模块时 模块内部的mutation和action的调用方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-07-07解决element-ui中下拉菜单子选项click事件不触发的问题
今天小编就为大家分享一篇解决element-ui中下拉菜单子选项click事件不触发的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-08-08Vue3响应式高阶用法之shallowReadonly()使用
在前端开发中,Vue3的shallowReadonly() API允许开发者创建部分只读的状态,这对于保持顶层属性不变而内部属性可变的场景非常有用,本文将详细介绍 shallowReadonly() 的使用方法及其应用场景,具有一定的参考价值,感兴趣的可以了解一下2024-09-09
最新评论