监听DOM尺寸变化 - ResizeObserver

这篇具有很好参考价值的文章主要介绍了监听DOM尺寸变化 - ResizeObserver。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、与 MutationObserver Api的区别

  • MutationObserver 主要用来监听 DOM 元素的属性和节点变化的,非 DOM 样式尺寸,可查看之前一篇 blog - DOM规范 - MutationObserver接口观察DOM元素的属性和节点变化
  • ResizeObserver 主要用来监听 DOM 元素的 内容区域 的尺寸变化,可以监听到 Element 的内容区域或 SVGElement 的边界框改变

二、用法

1. 构造函数,创建并返回一个 ResizeObserver 对象

const resizeObserver = new ResizeObserver(entries => {
  console.log('监听到了尺寸变化了...', entries)
})

resizeObserver.observe(document.getElementById('box'))

  • resizeObserver 是返回的一个操作对象,可调用其中的方法来监听、取消监听 DOM 元素等操作。

  • observe 方法用于开始观察指定的 Element 或 SVGElement 的尺寸变化。

  • entries 参数返回是一个数组,里面包含监听的每个 DOM 元素的相关信息,其中 contentRect 包含的是变化后的 内容区域 的尺寸信息。

监听DOM尺寸变化 - ResizeObserver,前端,javascript,开发语言,ecmascript

2. unobserve 结束观察指定的 Element 或 SVGElement

resizeObserver.unobserve(document.getElementById('box'))

3. disconnect 取消和结束目标对象上所有对 Element或 SVGElement 观察

resizeObserver.disconnect()

三、完整栗子及注意点~

  • #box1 是 标准盒模型(w3c标准),width = 内容区(content),height 同理。

  • #box2 是边框盒模型(IE盒模型),width = 内容区(content)+ 内边距(padding) + 内边框(border),height 同理。

<!DOCTYPE html>
<html lang="zh_CN">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>ResizeObserver 测试</title>
  <style>
    body {
      margin: 0;
    }
    #box1 {
      width: 200px;
      height: 200px;
      margin: 10px;
      padding: 10px;
      background-color: rgb(195, 245, 175);
    }
    #box2 {
      width: 200px;
      height: 200px;
      margin: 10px;
      padding: 10px;
      box-sizing: border-box; /** 注意,此处盒模型与 #box1 不同 */
      background-color: rgb(175, 182, 245);
    }
  </style>
</head>
<body>

  <button onclick="change1()">更改box1样式</button>
  <button onclick="change2()">更改box2样式</button>
  <button onclick="cancel1()">取消监听box1</button>
  <button onclick="cancel2()">取消监听box2</button>
  <button onclick="cancel()">取消所有元素</button>

  <div id="box1">这是一个测试盒子111~~~</div>

  <div id="box2">这是一个测试盒子222~~~</div>
  

  <script>
    const box1 = document.getElementById('box1')
    const box2 = document.getElementById('box2')
    let b1width = 1
    let b2width = 1

    const resizeObserver = new ResizeObserver(entries => {
      console.log('监听到了尺寸变化了...', entries)
    })

    resizeObserver.observe(box1)
    resizeObserver.observe(box2)

    function change1 () {
      const rect = box1.getBoundingClientRect()
      // box1.style.width = rect.width + 10 + 'px'
      // 因 #box1 是标准盒,所以边框(border)尺寸变化不会引起内容区(content)尺寸变化,所以以下语句`不会`触发观察的回调函数事件
      box1.style.border = 1 + b1width + 'px solid red'
      b1width ++
    }

    function change2 () {
      const rect = box2.getBoundingClientRect()
      // box2.style.width = rect.width + 10 + 'px'
      // 因 #box2 是边框盒,所以边框(border)尺寸变化会引起内容区(content)尺寸变化,所以以下语句`会`触发观察的回调函数事件
      box2.style.border = 1 + b2width + 'px solid red'
      b2width ++
    }

    function cancel1 () {
      resizeObserver.unobserve(box1)
    }

    function cancel2 () {
      resizeObserver.unobserve(box2)
    }

    function cancel () {
      resizeObserver.disconnect()
    }

  </script>
</body>
</html>

打印信息

监听DOM尺寸变化 - ResizeObserver,前端,javascript,开发语言,ecmascript
盒模型示意图

监听DOM尺寸变化 - ResizeObserver,前端,javascript,开发语言,ecmascript文章来源地址https://www.toymoban.com/news/detail-532539.html

到了这里,关于监听DOM尺寸变化 - ResizeObserver的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 前端设置页面字体尺寸跟随屏幕大小而进行变化

    越来越多的前端项目现在需要这个操作,其操作的原因很简单,你的项目可能跑在小尺寸分辨率的电脑上,也有可能在大尺寸的会议平板上,更有甚者是在LED上。那么如何让你的项目根据屏幕分辨率的大小而自动变化,修改页面展示字体以及调整尺寸呢? 按照我们所需功能,

    2023年04月12日
    浏览(38)
  • web前端javaScript笔记——(11)DOM

    属性                                     此事件发生在何时 onabort 图像的加载被中断。 onblur                                   元素失去焦点。 anchange                                 域的内容被改变 onclick  当用户点击某

    2024年01月19日
    浏览(41)
  • 前端基础自学整理|HTML + JavaScript + DOM事件

    目录 一、HTML 1、Html标签 2、Html元素 3、基本的HTML标签 二、CSS 样式 层叠样式表 三、JavaScript 使用示例 四、HTML DOM  通过可编程的对象模型,javaScript可以: window document 1、查找HTML元素 2、操作HTML元素 获取元素的属性 四、HTML DOM事件 ⚠️是DOM提供的API Html是用来描述网页的一

    2024年02月22日
    浏览(39)
  • layui中使用JavaScript监听下拉框(select)的变化,根据选中的值来决定是否显示或隐藏input元素

    HTML和CSS用于设置网页的基本结构和样式,而JavaScript则用于实现交互功能,比如根据下拉框的选项来控制input元素的显示或隐藏。 以下是一个简单的例子,使用JavaScript监听下拉框(select)的变化,然后根据选中的值来决定是否显示或隐藏input元素: HTML: JavaScript: 在这个例子中

    2024年02月04日
    浏览(40)
  • 〖大前端 - 基础入门三大核心之JS篇㉟〗- JavaScript 的DOM简介

    说明:该文属于 大前端全栈架构白宝书专栏, 目前阶段免费 , 如需要项目实战或者是体系化资源,文末名片加V! 作者:不渴望力量的哈士奇(哈哥),十余年工作经验, 从事过全栈研发、产品经理等工作,目前在公司担任研发部门CTO。 荣誉: 2022年度博客之星Top4、2023年度超

    2024年02月04日
    浏览(42)
  • 前端学习记录~2023.8.3~JavaScript重难点实例精讲~第5章 DOM与事件

    本章是第五章DOM与事件相关的内容。 DOM是文档对象模型,全称为Document Object Model。DOM用一个逻辑树来表示一个文档,树的每个分支终点都是一个节点,每个节点都包含着对象。DOM提供了对文档结构化的表述,通过绑定不同的事件可以改变文档的结构、样式和内容,从而能实现

    2024年02月12日
    浏览(37)
  • DOM变化观察者MutationObserver

    在这之前 DOM3 提供了 Mutation events 事件 DOMAttrModified DOMAttributeNameChanged DOMCharacterDataModified DOMElementNameChanged DOMNodeInserted DOMNodeInsertedIntoDocument DOMNodeRemoved DOMNodeRemovedFromDocument DOMSubtreeModified 可以监听到属性、文本内容、节点插入删除、子节点变化等事件。可是该事件 W3C 已废弃,

    2024年02月16日
    浏览(24)
  • 前端框架技术革新历程:从原生DOM操作、数据双向绑定到虚拟DOM等框架原理深度解析,Web开发与用户体验的共赢

    前端的发展与前端框架的发展相辅相成,形成了相互驱动、共同演进的关系。前端技术的进步不仅催生了前端框架的产生,也为其发展提供了源源不断的动力。 前端,即Web前端,是指在创建Web应用程序或网站过程中负责用户界面(User Interface, UI)构建与交互的部分,是用户与

    2024年04月26日
    浏览(47)
  • Vue3前端开发,watch侦听器的深度监听和精确监听

    Vue3前端开发,watch侦听器的深度监听和精确监听!今天和大家分享的内容是,关于watch的深度侦听和精确监听。 首先看一下,第一个案例,练习的是,深度监听的效果。默认是浅的侦听,是不会触发回调函数的。 如图,当我们点击按钮,修改num值的时候,触发了回调函数,在

    2024年01月23日
    浏览(30)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包