使用 Resize Observer API 构建测量工具

web api – 一个非常有趣且很少被充分探索的领域。然而,有大量独特且非常有用的 api 可以帮助您为您的项目创建工具。

例如,跟踪尺寸变化是创建动态、响应式体验的关键。这就是 resize observer api 发挥作用的地方。

在本文中,我们将构建一个测量工具,实时显示可调整大小的框的宽度和高度。这个项目以实用和交互的方式展示了 resize observer api 和 browser api 的强大功能。

什么是调整大小观察者 api?

resize observer api 是一项浏览器功能,可让您检测元素大小的更改。调整观察者大小适用于单个元素。它开箱即用,可以成为您构建响应式设计和动态 ui 的工具集的重要补充。

这就是它的伟大之处:

它轻巧且易于使用您可以跟踪特定元素的大小变化,而不仅仅是整个视口它非常适合构建响应式组件或可调整大小的小部件

我们正在建设什么

我们将创建一个可调整大小的框,其内部显示尺寸。当用户调整框的大小时,显示的尺寸将实时更新。

第 1 步:设置项目

首先,让我们设置项目的基本结构:

resize-tool/├── index.html├── styles.css├── script.js

第 2 步:标记

这是我们应用程序的简单布局。可调整大小的框包含一个文本范围来显示其尺寸:

      measuring tool with resize observer api    
width: 0px, height: 0px

第 3 步:设计应用程序样式

我们将添加一些样式,使可调整大小的框更具视觉吸引力:

body {  font-family: arial, sans-serif;  margin: 0;  padding: 0;  display: flex;  justify-content: center;  align-items: center;  height: 100vh;  background: #f0f0f0;}.container {  position: relative;  width: 80%;  height: 80%;}.resizable {  position: absolute;  width: 300px;  height: 200px;  border: 2px dashed #007bff;  background: rgba(0, 123, 255, 0.1);  display: flex;  justify-content: center;  align-items: center;  resize: both;  overflow: auto;} .resizable span {  background: white;  padding: 5px;  border-radius: 4px;  font-size: 20px;  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);}

第 4 步:添加实时调整大小跟踪

现在让我们使用 resize observer api 将项目变为现实:

const resizableBox = document.getElementById('resizableBox');const dimensions = document.getElementById('dimensions');const resizeObserver = new ResizeObserver(entries => {  for (let entry of entries) {    const { inlineSize: width, blockSize: height } = entry.borderBoxSize[0];    dimensions.textContent = `Width: ${Math.round(width)}px, Height: ${Math.round(height)}px`;  }});resizeObserver.observe(resizableBox);

第 5 步:测试工具

在浏览器中打开index.html 文件。拖动框的角来调整其大小。观看尺寸立即更新!

它是如何运作的

resize observer api 被初始化以监视 resizingbox 元素的大小变化。每当观察到的元素的大小发生变化时,它就会触发回调。resize observer entry 通过 borderboxsize 属性提供更新的尺寸。通过修改可调整大小的框中的 元素的文本内容来动态提取和显示更新的宽度和高度值。

结论

在本教程中,我们使用 resize observer api 构建了一个有趣且交互式的测量工具。该项目演示了浏览器 api 如何简化复杂的任务。
如果您尝试此操作或进一步扩展它,请随时在评论中分享您的创作!
另外,请查看 ckeditor 博客,了解有关富文本编辑器的文章,并立即注册免费试用,开始您的 ckeditor 5 之旅!

以上就是使用 Resize Observer API 构建测量工具的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1499934.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 22:10:24
下一篇 2025年12月18日 05:42:57

相关推荐

  • 掌握 Axios:简化 API 调用的 JavaScript 终极指南

    在快速发展的 Web 开发世界中,API 交互对于创建响应灵敏且可靠的应用程序非常重要。处理 HTTP 请求和响应时可能会非常复杂,尤其是在处理错误处理、数据操作和异步操作时。这就是 Axios 发挥作用的地方——一个强大且多功能的 JavaScript 库。 本博客是 axios 的终极指南,从基…

    2025年12月19日 好文分享
    000
  • 如何在 React Native 中集成 Tabby:分步指南

    将 tabby 集成到 react native 应用程序中可以是一个无缝的过程,但网上没有提供分步方法的综合指南。本文整合了多个来源的信息,为您提供在 react native 应用程序中实现 tabby 的清晰路线图。 第 1 步:安装 tabby sdk首先,您需要安装适用于 react na…

    好文分享 2025年12月19日
    000
  • 用例子解释 React 中的作用域上下文

    react作用域上下文详解:避免全局变量陷阱,提升组件性能 React Context并非简单的全局变量 JavaScript中的变量作用域局限于其定义的函数内。然而,React Context虽然具备全局访问能力,但其功能远不止于此。本文将深入探讨如何有效地控制Context的作用域,避免滥用导致…

    2025年12月19日
    000
  • 如何在 5 年内成为一名 Javascript 开发人员

    在 2025 年成为一名 javascript 开发人员需要掌握该语言、跟上不断发展的趋势以及构建现实世界的经验。这是分步指南: 第 1 步:学习基础知识了解编程基础知识:从变量、数据类型、循环、函数和数组等核心概念开始。学习 JavaScript 基础知识:专注于 ES6 功能(例如箭头函数、模板…

    好文分享 2025年12月19日
    000
  • LightUp 简介:人工智能驱动的网络注释

    在当今的数字世界中,我们不断受到信息的轰炸。无论是阅读文章、分析报告还是研究新主题,在选项卡之间跳转以收集背景信息或见解都会扰乱我们的流程和生产力。这就是 lightup 的用武之地:一款人工智能驱动的浏览器扩展程序,旨在帮助您保持专注、获得即时深度并直接在您正在查看的页面上扩展您的理解。 问题 您…

    2025年12月19日
    000
  • 使用 Bigjs 进行精确分配:处理舍入和剩余重新分配

    在处理大量的分数分配时,舍入误差和剩余的重新分配成为重大挑战。这些问题不仅限于财务计算;它们可以发生在其他领域,例如资源分配、任务调度或预算分配。在本文中,我们演示了一种使用 javascript 中的 big.js 库进行验证和测试的方法,以实现精确分配,同时有效处理舍入和剩余重新分配。 问题:在…

    好文分享 2025年12月19日
    000
  • 诺伊尔:框架奴隶制的终结

    嘿,你是框架奴隶吗? 辨别方法如下: 你花了 30 分钟配置路由器……只是为了让嵌套小部件工作。你们“钻探道具”比石油公司还深。你的 react useeffect 依赖项比你的购物清单还要长。你的 vue 观察者 就像感恩节你的姻亲一样互相争斗。您的 angular di …

    好文分享 2025年12月19日
    000
  • 拥抱正在消失的框架:高效 Web 开发的未来

    介绍 在不断发展的 web 开发领域,一种被称为“消失的框架”的新范式正在获得关注。这些框架旨在最大限度地减少或消除向客户端交付 javascript,从而增强性能和用户体验。以服务器端渲染 (ssr) 和静态站点生成 (ssg) 为重点,消失的框架正在彻底改变 web 应用程序的构建和部署方式。本…

    好文分享 2025年12月19日
    000
  • 上下文转储:简化 AI 文件准备

    如果您曾经需要为 ai 任务收集特定的项目文件,context dump 可能会有所帮助。这是一个简单的 cli 工具,用于生成项目结构和内容的 json 转储,以供 ai 使用。 它的作用 允许您使用复选框以交互方式选择文件。自动忽略 node_modules、.git 或 .gitignore …

    好文分享 2025年12月19日
    000
  • 在服务器上运行 Puppeteer:完整教程

    puppeteer 是一个 node.js 库,它提供了一个高级 api,用于通过 devtools 协议控制 chrome 或 chromium 浏览器。它是一个强大的工具,可用于网页抓取、自动化测试、捕获屏幕截图等。虽然在本地使用 puppeteer 很简单,但在服务器上运行它需要额外的考虑。本…

    好文分享 2025年12月19日
    000
  • 如何将额外数据附加到 Apollo Server 上的 GraphQL 响应

    假设我们希望在每个 graphql 响应中包含唯一的请求标识符。 我们可以通过向查询类型添加 requestid 字段,然后将该字段解析为我们在每个请求的上下文中设置的某个唯一标识符来实现这一点。但这不是一个完美的解决方案,因为我们必须在客户端的每个请求中包含该字段,并且它会稍微增加发送到服务器的请…

    2025年12月19日
    000
  • QuickUI: 轻量化前端框架

    原名:pdquickui,自 0.6.0 版本起更名为 quickuiquickui 是一个纯 javascript 开发的前端渲染框架。通过整合虚拟 dom 技术提升渲染效能,实现快速的数据响应和自动更新。 核心特色 高效虚拟 dom 透过精准的差异比对算法实现高效 dom 更新智慧属性更新系统,…

    好文分享 2025年12月19日
    000
  • JavaScript 中用于多线程的 Web Workers

    javascript 以单个序列运行代码,这称为单线程。这种设计非常适合 web 浏览器中的简单任务,但当主线程被复杂计算或后台操作等繁重任务阻塞时,可能会导致问题。这些任务可能会使页面变慢且无响应。为了解决这个问题,javascript 提供了 web workers,它允许您将繁重的任务移至单独…

    好文分享 2025年12月19日
    000
  • LeetCode 冥想:计算位数

    计数位的描述如下: 给定一个整数 n,返回一个数组 ans 长度 n 1 这样对于每个 i (0 例如: input: n = 2output: [0, 1, 1]explanation:0 –> 01 –> 12 –> 10 或者: input: n = 5output: …

    好文分享 2025年12月19日
    000
  • 如何在 CRA 弃用后创建 React 应用程序

    React团队弃用create-react-app (CRA)后,开发者们转向了Vite和Webpack等替代方案来构建React应用。本文将对比这两个工具,并提供各自的入门配置指南。 Vite vs. Webpack Vite 优点: 超快的开发服务器,配备即时热模块替换 (HMR) 功能;内置支…

    2025年12月19日
    000
  • 实时位置追踪器

    跟踪实时位置或通过连接的设备监控它,并使用连接的设备面板控制它。 github:- 马哈茂德·法尔汉 / 实时位置追踪器 实时位置跟踪器是一个 web 应用程序,允许用户跟踪设备的实时位置。该项目利用 leaflet 进行地图可视化,并利用 websocket 进行实时通信,使其成为车队管理、交付跟…

    2025年12月19日
    000
  • 对于短链接来说,URLdn 比 Bitly 更好吗?

    在url缩短方面,bitly长期以来一直是行业的主导者。然而,像 urldn.com 这样的新竞争对手正在兴起,声称提供更多功能和更好的用户体验。让我们比较一下这两种服务,看看哪一种更适合您的链接缩短需求。 用户界面和易用性 bitly:bitly 以其时尚直观的界面而闻名,适合初学者,可以轻松创建…

    好文分享 2025年12月19日
    000
  • 提高代码质量和性能的技巧

    React是一个强大的JavaScript库,用于构建用户界面。本文将分享五个实用技巧,帮助您编写更简洁、高效且易于维护的React代码,从而提升应用的质量和性能。 1. 条件渲染:优先使用三元运算符而非&&运算符 在React中,根据条件渲染组件或元素很常见。然而,使用&&…

    2025年12月19日
    000
  • 我在几个小时内建立了一个电影流媒体网站 - 这是它的进展情况

    48小时速成电影流媒体网站:开发历程分享 最近,我尝试了一个极具挑战性的个人项目:在48小时内,仅使用React前端框架和一些API,搭建一个无需后端和数据库的电影流媒体网站。 灵感源于我发现的一些利用TMDB等API和vidsrc.dev进行视频流传输的简易电影网站。 这个项目的目标并非追求完美代…

    2025年12月19日
    000
  • 使用 KaibanJS 彻底改变 GitHub 问题管理

    告别 github issue 管理的繁琐!使用 kaiban.js 自动化你的工作流程。kaiban.js 是一个用于构建多代理系统的 javascript 框架,结合 github issues 工具,可实现 issue 的自动化收集、分析和报告,从而节省时间并提升效率。 本文将深入探讨 Kai…

    2025年12月19日
    000

发表回复

登录后才能评论
关注微信