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

JS如何获取元素高度

在前端开发中获取元素高度是最基础也是最常用的操作之一。本文将详细介绍原生JavaScript和jQuery中获取元素高度的各种方法帮你彻底搞懂它们的区别 目录原生JavaScript获取高度jQuery获取高度各方法对比实际应用场景常见问题解决一、原生JavaScript获取高度1️⃣offsetHeight⭐ 最常用获取元素的可见高度包括✅ 内容高度content✅ 内边距padding✅ 边框border❌ 不包括外边距marginconstdivdocument.getElementById(myDiv);constheightdiv.offsetHeight;console.log(height);// 例如: 200px数字类型不带px2️⃣clientHeight获取元素的内部高度包括✅ 内容高度content✅ 内边距padding❌ 不包括边框border❌ 不包括外边距marginconstdivdocument.getElementById(myDiv);constheightdiv.clientHeight;console.log(height);// 例如: 198px不含2px边框3️⃣getBoundingClientRect().height获取元素的精确高度浮点数包括✅ 内容 padding border✅ 返回精确到小数点的值constdivdocument.getElementById(myDiv);constheightdiv.getBoundingClientRect().height;console.log(height);// 例如: 198.5px精确值4️⃣scrollHeight获取元素的完整内容高度包括✅ 内容高度即使被隐藏/滚动✅ 内边距padding❌ 不包括边框和外边距constdivdocument.getElementById(myDiv);constheightdiv.scrollHeight;// 常用于判断内容是否溢出if(div.scrollHeightdiv.clientHeight){console.log(内容溢出了需要滚动);}二、jQuery获取高度jQuery提供了更简洁的API底层其实还是调用原生方法。1️⃣.height()⭐ 最常用varh$(#myDiv).height();console.log(h);// 200数字类型等价于原生的offsetHeight不含margin2️⃣.innerHeight()varh$(#myDiv).innerHeight();等价于原生的clientHeight含padding不含border3️⃣.outerHeight()varh$(#myDiv).outerHeight();// 含padding bordervarh$(#myDiv).outerHeight(true);// 含padding border margin4️⃣.css(height)varh$(#myDiv).css(height);console.log(h);// 200px字符串类型带px⚠️注意返回的是字符串需要解析才能计算三、各方法对比 方法内容PaddingBorderMargin返回类型JSoffsetHeight✅✅✅❌数字JSclientHeight✅✅❌❌数字JSgetBoundingClientRect().height✅✅✅❌浮点数JSscrollHeight✅✅❌❌数字jQuery.height()✅✅✅❌数字jQuery.innerHeight()✅✅❌❌数字jQuery.outerHeight()✅✅✅❌数字jQuery.outerHeight(true)✅✅✅✅数字jQuery.css(height)✅❌❌❌字符串四、实际应用场景 场景1判断内容是否溢出constdivdocument.getElementById(content);if(div.scrollHeightdiv.clientHeight){console.log(内容溢出需要滚动条);div.style.overflowYauto;}场景2居中对齐垂直居中functioncenterVertically(){constcontainer$(#container);constchild$(#child);constcontainerHcontainer.height();constchildHchild.outerHeight();child.css(margin-top,(containerH-childH)/2);}场景3响应式布局$(window).resize(function(){constwindowH$(window).height();constheaderH$(#header).outerHeight();$(#main).css(height,windowH-headerH-50);});场景4获取视口高度// 原生JSconstviewportHeightwindow.innerHeight;// jQueryconstviewportHeight$(window).height();五、常见问题解决 ❌ 问题1获取的高度为0原因元素还没渲染完成就获取了解决// 方案1放在DOM ready中$(document).ready(function(){varh$(#myDiv).height();});// 方案2图片加载完成后获取$(img).on(load,function(){varh$(this).height();});❌ 问题2.css(height)返回 “auto”原因元素高度由内容撑开没有显式设置解决// 使用 offsetHeight 代替varhdocument.getElementById(myDiv).offsetHeight;// 或 jQueryvarh$(#myDiv).height();❌ 问题3隐藏元素获取高度为0原因display: none的元素无法获取可视高度解决// 临时显示获取constdiv$(#myDiv);div.show();consthdiv.height();div.hide();// 或使用 scrollHeight即使隐藏也能获取consthdiv[0].scrollHeight; 总结该用哪个需求推荐方法获取元素总高度含边框.height()/offsetHeight⭐获取内容内边距高度.innerHeight()/clientHeight获取包含margin的总高度.outerHeight(true)判断内容是否溢出scrollHeight clientHeight获取精确浮点高度getBoundingClientRect().height获取CSS设置的高度值.css(height) 一句话总结日常开发用.height()最方便需要精确计算用原生offsetHeight判断溢出用scrollHeight觉得有用点赞收藏不迷路 ❤️有问题欢迎评论区交流

相关文章:

JS如何获取元素高度

在前端开发中,获取元素高度是最基础也是最常用的操作之一。本文将详细介绍 原生JavaScript 和 jQuery 中获取元素高度的各种方法,帮你彻底搞懂它们的区别! 📖 目录 原生JavaScript获取高度jQuery获取高度各方法对比实际应用场景常…...

基于Roslyn为AI智能体生成C#代码地图:原理、实现与优化

1. 项目概述:为AI智能体绘制C#代码地图在AI智能体(Agent)技术日益成熟的今天,如何让这些“数字大脑”高效、准确地理解和操作复杂的代码库,成为了一个极具挑战性的工程问题。想象一下,你有一个精通C#的AI助…...

别再死记硬背DQN了!用游戏开发者的视角,图解Replay Buffer、LSTM等6大改进的实战意义

游戏开发者视角:图解DQN六大改进的实战意义 在游戏AI开发中,强化学习正逐渐成为构建智能对手和NPC的核心工具。但传统DQN算法在实际应用中常常遇到各种瓶颈——智能体学习效率低下、在复杂环境中表现不稳定、难以处理部分可观测状态等问题。这些问题恰恰…...

MATLAB Robotics Toolbox避坑实战:用Kinova Gen3机械臂手把手教你搞定碰撞检测

MATLAB Robotics Toolbox避坑实战:用Kinova Gen3机械臂手把手教你搞定碰撞检测 在机器人仿真领域,碰撞检测是确保机械臂安全运行的核心技术。许多初学者在使用MATLAB Robotics System Toolbox时,往往会在环境建模、参数设置和结果解析等环节…...

Armv8-A架构ID_ISAR寄存器详解与应用优化

1. Armv8-A架构ID_ISAR寄存器概述在Armv8-A架构中,ID_ISAR(Instruction Set Attribute Register)系列寄存器是理解处理器指令集特性的关键窗口。作为一位长期从事Arm架构开发的工程师,我发现这些寄存器在实际开发中经常被低估&…...

如何用ExifToolGUI批量管理照片元数据:告别命令行复杂操作

如何用ExifToolGUI批量管理照片元数据:告别命令行复杂操作 【免费下载链接】ExifToolGui A GUI for ExifTool 项目地址: https://gitcode.com/gh_mirrors/ex/ExifToolGui 你是否曾为几百张旅行照片的拍摄时间错误而烦恼?或者需要为大量图片批量添…...

投稿前一定要预审

作为一个拿过2项国自然青年基金、带过3届硕博生的高校青椒,今天给大家聊点掏心窝子的稿件打磨经验,都是我踩了无数坑、熬了无数夜攒出来的干货,不管你是要申基金、写毕业论文还是报专利,都能用得上。首先先给大家列3个科研人最容易…...

抖音无水印批量下载终极指南:3分钟学会免费下载视频、音乐和直播

抖音无水印批量下载终极指南:3分钟学会免费下载视频、音乐和直播 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fall…...

Pytorch图像去噪实战(八十二):Redis分布式限流实战,防止单用户高频调用拖垮服务

Pytorch图像去噪实战(八十二):Redis分布式限流实战,防止单用户高频调用拖垮服务 一、问题场景:一个用户疯狂调用接口,把所有人都拖慢了 前面我们做了用户配额系统,限制每日调用量。 但每日额度不能解决所有问题。 比如某个用户一天有 1000 次额度,但他在 1 分钟内全…...

Infineon DPS310压力传感器评估与开发实践

1. Infineon DPS310压力传感器评估环境解析在当今快速发展的消费电子领域,高精度压力传感器已成为无人机、可穿戴设备和室内外导航等应用的核心组件。作为行业领先的解决方案,Infineon DPS310凭借其出色的性能和完整的评估环境,为工程师提供了…...

ROS新手避坑指南:除了改hosts,rosdep update超时还有哪些‘冷门’但好用的招?

ROS新手避坑指南:rosdep update超时的全方位解决方案 1. 理解rosdep update的核心机制 rosdep作为ROS生态中的依赖管理工具,其update操作的本质是从GitHub仓库获取最新的软件包依赖关系映射。这个过程涉及三个关键环节: 元数据获取&#xff1…...

SQL库存管理系统核心设计:数据模型、事务控制与性能优化实战

1. 项目概述:一个基于SQL的库存管理系统的核心价值最近在GitHub上看到一个名为“inventory-management-system-sql”的项目,作者是sakibtheseeker。这个标题本身就像一把钥匙,直接指向了企业运营中一个永恒的核心痛点:如何高效、准…...

AgentNova智能体开发框架:从任务编排到工程实践全解析

1. 项目概述:AgentNova是什么,以及它为何值得关注最近在开源社区里,一个名为AgentNova的项目(由 VTSTech 团队维护)引起了我的注意。如果你和我一样,长期关注 AI 智能体(AI Agent)领…...

【AI面试临阵磨枪-57】如何防止 Prompt 注入、越狱、敏感信息泄露

一、 面试题目随着 Agent 接入业务系统,Prompt 注入(Injection)、越狱(Jailbreak)和敏感信息泄露(PII Leakage) 成为核心威胁。你如何从工程架构角度设计一套完整的安全防御体系?二、…...

开源虾类养殖监控系统:ESP32与MQTT物联网技术实践

1. 项目概述:一个开源虾类养殖监控系统的诞生最近在捣鼓一个挺有意思的项目,叫“openshrimp”。这名字一看就挺直白,开源(open)加上虾(shrimp),基本就点明了核心:一个开源…...

告别Hive慢查询:用Impala在CDH集群上实现秒级数据分析(实战避坑)

告别Hive慢查询:用Impala在CDH集群上实现秒级数据分析(实战避坑) 当你的Hive查询从30分钟降到3秒,数据工程师的幸福感会直接拉满。这不是理论上的性能优化,而是我们团队在CDH生产环境迁移Hive到Impala后的真实体验。如…...

书匠策AI(http://www.shujiangce.com)居然藏了个“期刊论文外挂“?

大家好,我是你们的论文写作搭子。 今天不聊选题有多头疼,也不扯文献有多难找,咱来聊点"偷塔"级别的操作——书匠策AI( 官网直达:www.shujiangce.com,微信公众号搜"书匠策AI"就能找到&…...

kill-doc:一键下载30+文档平台的终极解决方案,告别繁琐登录验证!

kill-doc:一键下载30文档平台的终极解决方案,告别繁琐登录验证! 【免费下载链接】kill-doc 看到经常有小伙伴们需要下载一些免费文档,但是相关网站浏览体验不好各种广告,各种登录验证,需要很多步骤才能下载…...

SDRPi平台OpenWifi实战:内核定制与驱动编译全流程解析

1. SDRPi与OpenWifi项目初探 第一次接触SDRPi平台时,我就被它的灵活性惊艳到了。这个基于树莓派架构的软件定义无线电开发板,配合OpenWifi开源项目,能实现从物理层到MAC层的完整WiFi协议栈开发。OpenWifi项目最大的特点是把FPGA和ARM处理器完…...

对TinyRedis中主从复制的理解

TinyRedis 中有 master 和 replica 两种角色。master 作为服务端监听端口,既可以管理普通客户端连接,也可以接收 replica 建立的复制连接。replica 本身也是一个服务端,但对于 master 来说,它会额外作为客户端主动创建 socket fd …...

避坑指南:树莓派USB摄像头识别出两个video设备怎么办?实测罗技免驱摄像头

树莓派USB摄像头双设备节点问题全解析:从原理到实战 当你兴冲冲地将罗技C310这样的免驱USB摄像头插入树莓派,准备开始你的计算机视觉项目时,却在终端输入ls /dev/video*后发现了video0和video1两个设备节点——这与大多数教程中描述的单一设备…...

VirtualMonitor虚拟显示器:终极多屏解决方案,零硬件成本扩展工作空间

VirtualMonitor虚拟显示器:终极多屏解决方案,零硬件成本扩展工作空间 【免费下载链接】VirtualMonitor 项目地址: https://gitcode.com/gh_mirrors/vi/VirtualMonitor 还在为单一屏幕无法满足多任务需求而烦恼吗?VirtualMonitor虚拟显…...

3分钟终极指南:免费视频下载插件VideoDownloadHelper完整使用教程

3分钟终极指南:免费视频下载插件VideoDownloadHelper完整使用教程 【免费下载链接】VideoDownloadHelper Chrome Extension to Help Download Video for Some Video Sites. 项目地址: https://gitcode.com/gh_mirrors/vi/VideoDownloadHelper 还在为无法下载…...

基于MCP协议构建Next.js项目智能中枢:自动化AI开发助手集成

1. 项目概述:一个为Next.js Prisma项目注入“项目智能”的MCP服务器如果你和我一样,日常开发重度依赖像Claude Code、Cursor这类AI编程助手,那你肯定遇到过这样的痛点:每次打开一个新项目,或者切换到一个复杂的模块&a…...

ARM架构TRFCR寄存器:调试与性能分析核心

1. ARM架构TRFCR寄存器深度解析在ARMv8/v9架构的调试系统中,Trace Filter Control Register(TRFCR)扮演着至关重要的角色。这个32位系统寄存器专门用于控制处理器在EL1(特权模式)下的跟踪功能,是性能分析和…...

时钟同步技术中的滤波与拥塞标记原理详解

1. 时钟同步技术中的滤波与拥塞标记原理在网络时钟同步领域,延迟测量是影响精度的关键因素。传统时钟同步协议(如PTP、NTP)通过交换时间戳报文来计算时钟偏移,但网络中的排队延迟会引入随机误差。这种误差表现为延迟分布的方差&am…...

安卓本地AI助手部署:基于GlibClaw与Magisk模块的离线解决方案

1. 项目概述:在安卓设备上部署AI助手如果你是一个喜欢折腾安卓设备的极客,或者是一个对AI应用本地化部署感兴趣的开发者,那么你很可能已经厌倦了那些必须联网、隐私存疑的云端AI助手。最近,我在一个开源社区里发现了一个名为GlibC…...

AI能替代演员吗?影视行业真正的危机,不是技术,而是内容失去灵魂

【摘要】当生成式AI的技术浪潮冲刷着影视工业的每一个角落,关于“演员替代”的讨论已然沸腾。然而,票房数据的结构性下滑与观众对“AI艺人”的本能抵制,共同揭示了一个更深层次的困境。这场变革的核心并非技术与人力的直接对抗,而…...

抖音开放平台实战指南:从授权码到接口调用的全链路解析

1. 抖音开放平台入门:从零开始接入 刚接触抖音开放平台的开发者可能会觉得一头雾水,其实整个流程可以简化为三个核心步骤:获取授权码、换取访问令牌、调用接口获取数据。我刚开始对接时也踩过不少坑,比如回调地址配置错误、token过…...

别只盯着算法!聊聊Apollo架构里那些容易被忽略的‘基建’:RTOS、ROS改造与数据兼容性

自动驾驶系统的隐形支柱:RTOS、通信框架与数据协议的工程实践 在自动驾驶技术的聚光灯下,感知算法和路径规划往往占据C位,而那些默默支撑整个系统稳定运行的底层组件却鲜少被讨论。就像一座冰山,水面之上的算法模型固然耀眼&…...