当前位置: 首页 > news >正文

dom 相关api getBoundingClientRect

getBoundingClientRect()是 JavaScript 中一个非常重要的DOM API,用于获取元素在视口(viewport)中的位置和尺寸信息

const rect = element.getBoundingClientRect();

返回一个DOMRect对象,包含以下只读属性(单位:像素):

属性含义
x/left元素左边缘到视口左侧的距离
y/top元素上边缘到视口顶部的距离
right元素右边缘到视口左侧的距离
bottom元素下边缘到视口顶部的距离
width元素宽度(等价于right - left
height元素高度(等价于bottom - top

💡 注意:xleft是等价的,ytop也是等价的(现代浏览器支持x/y)。

🖼️ 图示说明

视口顶部 │ │ top (y) │ ↓ ├───────────────┐ ← left (x) │ │ │ 元素 │ → right │ │ └───────────────┘ │ │ bottom ↓ 视口底部

假设你有一个很长的网页,其中有一个按钮:

<!-- 页面顶部 --> <h1>欢迎来到我的网站</h1> <!-- 中间有很多内容(比如 2000px 高的空白) --> <div style="height: 2000px; background: #eee;"></div> <!-- 目标按钮:距离页面顶部 2100px --> <button id="myBtn">点击我</button>
  • 按钮在整个页面中的绝对位置是:top = 2100px(从页面最顶端算起)
  • 浏览器窗口高度是:800px

情况一:页面没有滚动(刚打开时)

  • 你看到的是页面顶部(<h1>
  • 按钮在屏幕下方很远,甚至看不见
  • 此时调用:
const btn = document.getElementById('myBtn'); console.log(btn.getBoundingClientRect().top); // 输出:2100

✅ 因为视口顶部就是页面顶部,所以top = 2100(按钮在视口下方 2100px)

情况二:你向下滚动了 1500px

  • 现在你看到的是页面中间部分
  • 按钮离你更近了,可能已经出现在屏幕中
  • 此时再调用:
console.log(btn.getBoundingClientRect().top); // 输出:600

❓ 为什么变成600

因为:

  • 按钮在页面中的绝对位置还是2100px
  • 但你已经向下滚动了 1500px,所以视口的“顶部”现在对应的是页面的1500px
  • 所以按钮到当前视口顶部的距离 =2100 - 1500 = 600px

getBoundingClientRect().top始终告诉你:“这个元素现在离你眼前屏幕顶部有多远”

关键结论

  • getBoundingClientRect()的坐标系原点是当前可见屏幕的左上角(视口),不是整个网页的左上角。
  • 自动排除了滚动的影响,直接告诉你“元素现在在屏幕什么位置”。
  • 如果你想得到在整个页面中的绝对位置,需要手动加上滚动偏移:

js

编辑

const rect = el.getBoundingClientRect(); const absoluteTop = rect.top + window.scrollY; const absoluteLeft = rect.left + window.scrollX;
http://www.zskr.cn/news/112761.html

相关文章:

  • 微算法科技(NASDAQ MLGO)链下与机器学习融合:革新区块链可扩展性
  • vue基于Springboot框架的在线教育课程购买作业平台的设计与实现
  • vue基于Springboot框架网上电子书店商城好书推荐管理系统 论坛
  • 计算机毕业设计springboot健身房管理系统 基于Spring Boot的健身房信息化管理平台设计与实现 Spring Boot框架下的健身房综合管理系统开发
  • Linux 环境下 SQL Server 自动收缩日志作业创建脚本(Shell 版)
  • RPA实战|亚马逊账号申诉自动化!3分钟搞定申诉材料,成功率提升300%[特殊字符]
  • 【Java毕设全套源码+文档】基于java的在线作业管理系统设计与实现(丰富项目+远程调试+讲解+定制)
  • 【Java毕设全套源码+文档】基于Java的在线考试系统设计与实现(丰富项目+远程调试+讲解+定制)
  • 【Java毕设全套源码+文档】基于Java的音乐网站的设计与分析(丰富项目+远程调试+讲解+定制)
  • LeetCode热题100--55. 跳跃游戏--中等
  • 属于“AI建造者们”的2025年 “时代”为何选择百度
  • 《#{} vs ${}:MyBatis 里这俩符号,藏着性能与安全的 “生死局”》
  • Comsol 助力多裂纹水力压裂扩展研究
  • Windows任务管理器的作用
  • Windows任务管理器中的内存指标解读
  • Windows任务管理器中CPU相关指标怎么看?
  • SDUT Java 类和对象
  • 基于单片机的智能衣柜
  • 【SVD】SVD数学推导,物理意义及其经典应用
  • 基于单片机的智能密码锁设计
  • RAG技术全解析:从基础检索到智能体驱动的AI系统必学必藏
  • 基于单片机的节能窗控制系统设计
  • LobeChat心理情绪日记分析工具
  • 【情感】程序人生之理想主义的情感希冀(个人背景、兴趣爱好、爱情观、理想的另一半、期待什么样的生活等)
  • 1688 商品详情接口深度解析:从百川签名突破到供应链数据重构
  • 【go语言 | 第5篇】channel——多个goroutine之间通信
  • LobeChat公益活动策划方案生成
  • 探秘!宜宾这5家家电门店,质量好到超乎想象!
  • 大模型推理基石:如何用 C++ 封装 CUDA API?(含源码与原理解析)
  • 基于大数据旅游分析可视化平台 数据大屏 游客分析+商家分析+舆情分析 Flask框架 (附源码)