【JS】1684- 重学 JavaScript API - Resize Observer API

2023-11-23 18:30

本文主要是介绍【JS】1684- 重学 JavaScript API - Resize Observer API,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

0a214856d12f648f655d9991147c61a1.jpeg

前期回顾:

1. Page Visibility API

2. Broadcast Channel API

3. Beacon API

🏝 什么是 Resize Observer API

Resize Observer API[1] 可以帮助我们监听元素尺寸的变化,并在尺寸变化时执行一些操作。例如,我们可以使用 Resize Observer API 来动态调整 UI 布局、加载或卸载图片等。

🎨 如何使用 Resize Observer API

使用 Resize Observer API 非常简单。接下来我会通过 3 个使用示例带大家熟悉 Resize Observer API。

1.监听元素尺寸的变化

在实际应用中,我们通常需要「监听元素尺寸的变化」,并在「尺寸变化时执行一些操作」。例如,我们可能需要动态调整 UI 布局,以适应不同尺寸的屏幕或设备。下面是一个监听元素尺寸变化的示例:

// 创建一个 ResizeObserver 实例
const observer = new ResizeObserver((entries) => {for (let entry of entries) {console.log(entry.target, entry.contentRect);// 动态调整 UI 布局const { width, height } = entry.contentRect;// ...}
});// 监听一个元素
const element = document.getElementById("my-element");
observer.observe(element);

在上面的示例中,我们使用 Resize Observer API 来监听 ID 为 "my-element" 的元素的尺寸变化。在回调函数中,我们可以获取元素的尺寸信息,并使用这些信息来动态调整 UI 布局。

2.监听元素内部的尺寸变化

除了监听元素本身的尺寸变化外,我们还可以监听「元素内部」的尺寸变化。例如,当元素内部的文本或图像发生变化时,我们可能需要重新计算元素的尺寸,并相应地调整 UI 布局。下面是一个监听元素内部尺寸变化的示例:

// 创建一个 ResizeObserver 实例
const observer = new ResizeObserver((entries) => {for (let entry of entries) {console.log(entry.target, entry.contentRect);// 动态调整 UI 布局const { width, height } = entry.contentRect;// ...}
});// 监听一个元素的内部尺寸变化
const element = document.getElementById("my-element");
observer.observe(element, { box: "content-box" });

在上面的示例中,我们使用 Resize Observer API 来监听 ID 为 "my-element" 的「元素内部」的尺寸变化。我们传递了一个选项对象,其中 box 属性设置为 content-box,表示要监听元素内部的尺寸变化。

3.React 中使用 Resize Observer API

当然,我们也可以在 React 或 Vue 中使用,还可以使用第三方库来简化 Resize Observer API 的使用。例如,在 React 中,您可以使用 react-resize-observer 库来监听元素的尺寸变化。以下是一个使用 react-resize-observer 库的示例:

import React, { useState } from "react";
import { ResizeObserver } from "@juggle/resize-observer";
import { useResizeObserver } from "react-resize-observer";function MyComponent() {const [width, setWidth] = useState(0);const [height, setHeight] = useState(0);const onResize = (entry) => {const { width, height } = entry.contentRect;setWidth(width);setHeight(height);};const { ref } = useResizeObserver({ onResize, polyfill: ResizeObserver });return <div ref={ref}>My content goes here</div>;
}

在上面的示例中,我们使用了 react-resize-observer[2] 和 @juggle/resize-observer[3] 两个库来监听元素的尺寸变化。我们使用 useResizeObserver() hook 来创建一个 ResizeObserver 实例,并在回调函数中更新组件的状态。

👍 Resize Observer API 的实际应用

Resize Observer API 可以在很多实际场景中使用。下面是一些常见的应用场景:

1.响应式布局

使用 Resize Observer API 可以轻松实现「响应式布局」。例如,当屏幕尺寸发生变化时,我们可以监听根元素的尺寸变化,并相应地调整 UI 布局。 以下是使用 Resize Observer API 实现的示例代码:

<!-- 响应式布局示例代码 -->
<div class="container" id="responsive-container"><div class="row"><div class="col-sm-4"><p>First column content</p></div><div class="col-sm-4"><p>Second column content</p></div><div class="col-sm-4"><p>Third column content</p></div></div>
</div><script>const container = document.getElementById("responsive-container");const resizeObserver = new ResizeObserver((entries) => {for (let entry of entries) {const { width } = entry.contentRect;if (width >= 768) {container.classList.add("large-device");} else {container.classList.remove("large-device");}}});resizeObserver.observe(container);
</script><style>.large-device .col-sm-4 {width: 33.33%;}
</style>

2.图片懒加载

使用 Resize Observer API 可以实现「图片懒加载」。例如,当图片元素进入可视区域时,我们可以监听其尺寸变化,并在元素完全加载后显示图片。 以下是一个使用 Resize Observer API 实现图片懒加载的示例代码:

<!-- HTML -->
<img data-src="https://example.com/image.jpg" alt="My image" /><script>// JavaScriptconst observer = new ResizeObserver((entries) => {for (let entry of entries) {if (entry.isIntersecting) {const img = entry.target;const src = img.getAttribute("data-src");if (src) {img.setAttribute("src", src);img.removeAttribute("data-src");}}}});const images = document.querySelectorAll("img[data-src]");images.forEach((img) => {observer.observe(img);});
</script>

在上面的代码中,我们使用 Resize Observer API 来监听图片元素的尺寸变化。当图片元素进入可视区域时,我们将其 data-src 属性中的 URL 赋值给其 src 属性,从而实现图片懒加载的效果。同时,我们使用 Intersection Observer API 来监听图片元素是否进入可视区域。 注意,在上面的代码中,我们还需要为图片元素设置一个 data-src 属性,其中包含要加载的图片的 URL。这样可以避免在页面加载时立即加载所有图片,从而提高页面性能。

3.自适应 UI 组件

使用 Resize Observer API 可以轻松实现自适应 UI 组件。例如,当 UI 组件内部的元素数量或尺寸发生变化时,我们可以监听其尺寸变化,并相应地调整 UI 布局。

🧭 Resize Observer API 的兼容性

Resize Observer API 是一个比较新的 Web API,目前仅在现代浏览器中得到支持。以下是 Resize Observer API 的兼容性情况:

  • Chrome 64+ ✅

  • Firefox 69+ ✅

  • Safari 14.1+ ✅

  • Edge 79+ ✅

  • Opera 51+ ✅

dabe35d49893715dc5d44a69dc18de8e.png
image.png

详细兼容性情况可以在 Can I Use[4] 网站上查看。

📋 Resize Observer API 优缺点

接下来看看 Resize Observer API 的优点和缺点:

1.优点

  • 可以用于检测元素大小的变化,而无需轮询或使用其他检测技术。

  • 它能够监听「多个元素」的大小变化,并且只在元素大小发生变化时才会触发回调函数。

  • 可以检测到「任何元素」的大小变化,不仅限于可见元素。

  • 相比于其他检测技术(如 window.resize 事件),Resize Observer API 更加稳定,因为它可以避免由于事件的频繁触发而导致的性能问题。

2.缺点

  • 不是所有浏览器都支持,特别是较旧的浏览器。

  • 因为 Resize Observer API 的回调函数是异步执行的,所以它不能保证在元素大小变化之后立即执行。

  • Resize Observer API 不会提供元素的具体大小值,只提供了尺寸的变化信息。如果需要获取元素的具体大小值,开发人员需要自己计算。

🎯 总结

在本文中,我们介绍了 Resize Observer API 的基本使用方法,并提供了一些示例代码来帮助大家更好地理解和使用该 API。希望本文能够帮助您更好地理解和使用 Resize Observer API。 如果您想了解更多信息,请参阅下面的参考资料:

  • MDN Web Docs: Resize Observer API[5]

  • W3C: Resize Observer[6]

Reference

[1]

Resize Observer API: https://developer.mozilla.org/en-US/docs/Web/API/Resize_Observer_API

[2]

react-resize-observer: https://github.com/bootstarted/react-resize-observer

[3]

@juggle/resize-observer: https://github.com/juggle/resize-observer

[4]

Can I Use: https://caniuse.com/?search=Resize%20Observer%20API

[5]

MDN Web Docs: Resize Observer API: https://developer.mozilla.org/en-US/docs/Web/API/ResizeObserver

[6]

W3C: Resize Observer: https://www.w3.org/TR/resize-observer/

这篇关于【JS】1684- 重学 JavaScript API - Resize Observer API的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/419894

相关文章

SpringBoot基于沙箱环境实现支付宝支付教程

《SpringBoot基于沙箱环境实现支付宝支付教程》本文介绍了如何使用支付宝沙箱环境进行开发测试,包括沙箱环境的介绍、准备步骤、在SpringBoot项目中结合支付宝沙箱进行支付接口的实现与测试... 目录一、支付宝沙箱环境介绍二、沙箱环境准备2.1 注册入驻支付宝开放平台2.2 配置沙箱环境2.3 沙箱

使用Java发送邮件到QQ邮箱的完整指南

《使用Java发送邮件到QQ邮箱的完整指南》在现代软件开发中,邮件发送功能是一个常见的需求,无论是用户注册验证、密码重置,还是系统通知,邮件都是一种重要的通信方式,本文将详细介绍如何使用Java编写程... 目录引言1. 准备工作1.1 获取QQ邮箱的SMTP授权码1.2 添加JavaMail依赖2. 实现

Java嵌套for循环优化方案分享

《Java嵌套for循环优化方案分享》介绍了Java中嵌套for循环的优化方法,包括减少循环次数、合并循环、使用更高效的数据结构、并行处理、预处理和缓存、算法优化、尽量减少对象创建以及本地变量优化,通... 目录Java 嵌套 for 循环优化方案1. 减少循环次数2. 合并循环3. 使用更高效的数据结构4

java两个List的交集,并集方式

《java两个List的交集,并集方式》文章主要介绍了Java中两个List的交集和并集的处理方法,推荐使用Apache的CollectionUtils工具类,因为它简单且不会改变原有集合,同时,文章... 目录Java两个List的交集,并集方法一方法二方法三总结java两个List的交集,并集方法一

Spring AI集成DeepSeek三步搞定Java智能应用的详细过程

《SpringAI集成DeepSeek三步搞定Java智能应用的详细过程》本文介绍了如何使用SpringAI集成DeepSeek,一个国内顶尖的多模态大模型,SpringAI提供了一套统一的接口,简... 目录DeepSeek 介绍Spring AI 是什么?Spring AI 的主要功能包括1、环境准备2

Spring AI集成DeepSeek实现流式输出的操作方法

《SpringAI集成DeepSeek实现流式输出的操作方法》本文介绍了如何在SpringBoot中使用Sse(Server-SentEvents)技术实现流式输出,后端使用SpringMVC中的S... 目录一、后端代码二、前端代码三、运行项目小天有话说题外话参考资料前面一篇文章我们实现了《Spring

Spring AI与DeepSeek实战一之快速打造智能对话应用

《SpringAI与DeepSeek实战一之快速打造智能对话应用》本文详细介绍了如何通过SpringAI框架集成DeepSeek大模型,实现普通对话和流式对话功能,步骤包括申请API-KEY、项目搭... 目录一、概述二、申请DeepSeek的API-KEY三、项目搭建3.1. 开发环境要求3.2. mav

Springboot的自动配置是什么及注意事项

《Springboot的自动配置是什么及注意事项》SpringBoot的自动配置(Auto-configuration)是指框架根据项目的依赖和应用程序的环境自动配置Spring应用上下文中的Bean... 目录核心概念:自动配置的关键特点:自动配置工作原理:示例:需要注意的点1.默认配置可能不适合所有场景

使用Apache POI在Java中实现Excel单元格的合并

《使用ApachePOI在Java中实现Excel单元格的合并》在日常工作中,Excel是一个不可或缺的工具,尤其是在处理大量数据时,本文将介绍如何使用ApachePOI库在Java中实现Excel... 目录工具类介绍工具类代码调用示例依赖配置总结在日常工作中,Excel 是一个不可或缺的工http://

Java8需要知道的4个函数式接口简单教程

《Java8需要知道的4个函数式接口简单教程》:本文主要介绍Java8中引入的函数式接口,包括Consumer、Supplier、Predicate和Function,以及它们的用法和特点,文中... 目录什么是函数是接口?Consumer接口定义核心特点注意事项常见用法1.基本用法2.结合andThen链