javascript怎么获取隐藏元素的高度

获取方法:1、引入jquery文件;2、使用“$(#id值)”语句根据指定id值获取隐藏元素对象;3、使用“元素对象.height()”语句来获取隐藏元素的高度。

本教程操作环境:windows7系统、javascript1.8.5&&jquery3.1.0版、Dell G3电脑。

首先,正常情况下,确保div是有高度的。

<!DOCTYPE html>
<html>
<head>
    <Meta charset=UTF-8>
    <title>Document</title>
    <script src=jquery-3.1.0.min.js type=text/javascript></script>
</head>
<body>
    <div id=div>
        <div id=divsub>
            子div内容,需要获取我的高度
        </div>
    </div>
</body>
<script type=text/javascript>
    console.log($(#div).height())  //21
    console.log($(#divsub).height()) //21
</script>
</html>

1.png

当我们在id为div的元素上加了 style=display:none; 之后,重新运行代码,结果如下:

2.png

可以看到,父div能正常获取值,而子div已经获取不到高度了。

当我们把 style=display:none; 改成 style=visibility: hidden; 后,仍能够正常获取。但是div的位置还在。

3.png

于是,就有了下面的解决方案,使用visibility隐藏,然后把div移到屏幕之外看不见的地方就可以了。

<!DOCTYPE html>
<html>
<head>
    <Meta charset=UTF-8>
    <title>Document</title>
    <script src=jquery-3.1.0.min.js type=text/javascript></script>
</head>
<body>
    <div id=div style=visibility:hidden; position: absolute;top:-9999px;left:-9999px;>
        <div id=divsub>
            子div内容,需要获取我的高度
        </div>
    </div>
</body>
<script type=text/javascript>
    console.log($(#div).height())  
    console.log($(#divsub).height())
</script>
</html>

【推荐学习:javascript高级教程

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...