使用ResizeObserver监测元素尺寸变化

监测 DOM 元素的尺寸变化在许多场景中是必要的,比如响应式布局、动态调整元素大小等。传统的 window.resize 事件只能监测窗口尺寸变化,但无法直接跟踪某个具体 DOM 元素的大小变化。为此,JavaScript 提供了一个冷门却非常实用的 API ------ ResizeObserver

什么是 ResizeObserver

ResizeObserver API 允许你监听某个 DOM 元素的尺寸变化,并在变化时触发回调函数。这对于创建自适应布局、图表大小调整等场景非常有用。

基本用法

html 复制代码
<div id="resize-me" style="width: 200px; height: 200px; background-color: lightblue;">
  改变我的尺寸
</div>
javascript 复制代码
// 选择要观察的元素
const resizeElement = document.getElementById('resize-me');

// 创建 ResizeObserver 实例
const resizeObserver = new ResizeObserver(entries => {
  entries.forEach(entry => {
    console.log('元素尺寸变化:', entry.contentRect.width, entry.contentRect.height);
  });
});

// 开始观察元素
resizeObserver.observe(resizeElement);

// 模拟尺寸变化
setTimeout(() => {
  resizeElement.style.width = '400px';
  resizeElement.style.height = '400px';
}, 3000);

应用场景

  1. 自适应组件:当元素尺寸变化时动态调整内容或样式。
  2. 图表更新:随着容器大小改变,重新渲染图表以保持合适的比例。
  3. 文本换行处理:根据父元素的尺寸变化自动调整文本排版。

优势

  • 专门针对元素大小变化设计,比 window.resize 更加精确。
  • 支持多个元素的同时监控。
  • 不影响页面性能,避免了频繁的手动检查。

结语

ResizeObserver 是一个实用的 API,可以为你带来更高效的布局调整方式,特别是在响应式设计和动态组件中。


这两篇文章介绍了 IntersectionObserverResizeObserver,它们虽然不如一些常用的 API 那么广为人知,但在实际开发中非常有用。希望对你有所帮助!

相关推荐
喜欢吃鱿鱼5 分钟前
DES加解密(附带解决转义问题)-VUE
开发语言·前端·javascript
愚者游世7 分钟前
variadic templates(可变参数模板)各版本异同
开发语言·c++·程序人生·面试
腹黑天蝎座8 分钟前
前端性能优化实战指南:从原理到落地的全方位解决方案
前端·性能优化·监控
忆往wu前13 分钟前
一文通透 Vue动态组件体系:插槽|数据监听|组件通信|动态切换|缓存—闭环
前端·面试
奇奇怪怪的问题14 分钟前
问题总结:关于封装axios问题,导致外部使用接口报错,无法进入error回调
前端·axios
Jenlybein14 分钟前
速学 VS Code 插件开发入门,客制化你的开发体验
前端·javascript·visual studio code
Cosolar17 分钟前
大模型应用开发工程师 · 学习路线(完整技术栈版)
人工智能·面试·架构
haina201936 分钟前
海纳AI正式发布“面试Agent”——实现千岗千面与人机共管的智面新纪元
人工智能·面试·职场和发展
qq_437100661 小时前
SSE 流式响应(Server-Sent Events)
前端·sse
十六年开源服务商1 小时前
游戏与设计驱动WordPress建站2026
java·前端·游戏