Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 764|回复: 0

JS获取display为none的隐藏元素的宽度和高度的解决方案

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-4-16 13:27:04 | 显示全部楼层 |阅读模式

    有时候,我们一进入页面,就需要获取display为none元素的物理尺寸(宽高),或获取display为none元素的子元素的物理尺寸(宽高),本篇文章就如何解决以上问题给出自己的解决方案

    获取display为none元素的子元素的物理尺寸
    方案一思路:

    1、利用给元素添加行内样式:display:block;position:absolute;z-index:-1000
    2、让隐藏元素变成block同时利用定位带出可视区,再获取下面元素的物理尺寸后
    3、再给它还原成display为none,最后返回结果

     1 <!DOCTYPE html>
     2 <html lang="en">
     3 <head>
     4     <meta charset="UTF-8">
     5     <title>获获取display为none元素的子元素的物理尺寸 :解决方案一</title>
     6 </head>
     7 <body>
     8     <div class="wrap"  style="display: none;">
     9         <ul>
    10             <li>
    11                 <p>前端技术</p>
    12                 <p>前端技术</p>
    13                 <p>前端技术</p>
    14                 <p>前端技术</p>
    15                 <p>前端技术</p>
    16             </li>
    17             <li>
    18                 <p>前端技术</p>
    19                 <p>前端技术</p>
    20                 <p>前端技术</p>
    21                 <p>前端技术</p>
    22                 <p>前端技术</p>
    23                 <p>前端技术</p>
    24                 <p>前端技术</p>
    25                 <p>前端技术</p>
    26                 <p>前端技术</p>
    27             </li>
    28             <li>
    29                 <p>前端技术</p>
    30                 <p>前端技术</p>
    31                 <p>前端技术</p>
    32             </li>
    33         </ul>
    34     </div>
    35 </body>
    36 <script>
    37 
    38 //  获取display为none元素下的子元素的高度
    39 function getHeight(parentSelector,childSelector){
    40     let wrap =  document.querySelector(parentSelector);
    41     let  aLi =  wrap.querySelectorAll(childSelector);
    42     let  arr =  [];
    43     wrap.style.cssText = `display:block;position:absolute;z-index:-1000;`
    44     for (var i = 0; i < aLi.length; i++) {
    45         arr.push(aLi.offsetHeight)
    46     }
    47     wrap.style.cssText = "display:none;"
    48     return arr
    49 }
    50 console.log(getHeight('.wrap','li'))
    51 </script>
    52 </html>

    方案二思路:不推荐
    1、这个方法需要用户事件触发让隐藏元素显示出来
    2、开启一个定时器,间隔判断隐藏元素是否显示了
    3、如果显示了,清除定时器,拿到结果再去操作

     1 <!DOCTYPE html>
     2 <html lang="en">
     3 <head>
     4     <meta charset="UTF-8">
     5     <title>获获取display为none元素的子元素的物理尺寸 :解决方案二</title>
     6 </head>
     7 <body>
     8     <div class="wrap"  style="display: none;">
     9         <ul>
    10             <li>
    11                 <p>前端技术</p>
    12                 <p>前端技术</p>
    13                 <p>前端技术</p>
    14                 <p>前端技术</p>
    15                 <p>前端技术</p>
    16             </li>
    17             <li>
    18                 <p>前端技术</p>
    19                 <p>前端技术</p>
    20                 <p>前端技术</p>
    21                 <p>前端技术</p>
    22                 <p>前端技术</p>
    23                 <p>前端技术</p>
    24                 <p>前端技术</p>
    25                 <p>前端技术</p>
    26                 <p>前端技术</p>
    27             </li>
    28             <li>
    29                 <p>前端技术</p>
    30                 <p>前端技术</p>
    31                 <p>前端技术</p>
    32             </li>
    33         </ul>
    34     </div>
    35 
    36     <button class="btn">按钮</button>
    37 </body>
    38 <script>
    39 
    40 //  获取display为none元素下的子元素的高度
    41 
    42 let wrap =  document.querySelector('.wrap');
    43 let  aLi =  wrap.querySelectorAll('li');
    44 let  arr =  [];
    45 let timer=null;
    46 timer = setInterval(function(){
    47     // 用户操作后 让隐藏隐藏元素显示了 则获取结果 清除定时器
    48     if(wrap.offsetHeight > 0){
    49         for (var i = 0; i < aLi.length; i++) {
    50             arr.push(aLi.offsetHeight)
    51         }
    52         clearInterval(timer)
    53 
    54         console.log(arr)
    55     }
    56 },1000)
    57     
    58 document.querySelector('.btn').onclick=function(){
    59     wrap.style.cssText = "display:block;"
    60 }
    61 </script>
    62 </html>

    获取display为none元素的物理尺寸
    解决思路:

    1、利用给元素添加行内样式:visibility:hidden
    2、让隐藏元素变成有物理尺寸存在,但不可见
    3、再给它还原成display为none,最后返回结果

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>获取display为none元素的物理尺寸解决方案</title>
    </head>
    <body>
        <div class="container" style="display: none;">
            <p>前端技术</p>
            <p>前端技术</p>
            <p>前端技术</p>
        </div>
    </body>
    <script>
    
    //  获取display为none元素的高度
    function getSizeAttr(elementSelector,attrName){
        let oDiv =  document.querySelector(elementSelector);
        oDiv.style.cssText = `visibility:hidden`
        let attr = {
            height: oDiv.offsetHeight,
            width: oDiv.offsetWidth,
            offsetLeft: oDiv.offsetLeft,
            offsetTop: oDiv.offsetTop
        }
        oDiv.style.cssText = `display:none`;
        return attr[attrName]
    }
    console.log(getSizeAttr('.container','width'))
    console.log(getSizeAttr('.container','height'))
    console.log(getSizeAttr('.container','offsetLeft'))
    console.log(getSizeAttr('.container','offsetTop'))
    </script>
    </html>

    小结:利用先把所有隐藏元素变成可以获取物理尺寸,获取完毕再给它变成隐藏,再返回我们需求的物理尺寸是关键。

    转自http://moxiaofei.com/2019/07/13/getsize/

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-24 16:28 , Processed in 0.062780 second(s), 27 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表