亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

javascript獲取隱藏元素(display:none)的高度和寬度的方法

2019-11-20 14:45:56
字體:
來源:轉載
供稿:網友

js獲取可見元素的尺寸還是比較方便的,這個可以直接使用這個方法:

復制代碼 代碼如下:

function getDefaultStyle(obj,attribute){ // 返回最終樣式函數,兼容IE和DOM,設置參數:元素對象、樣式特性
 return obj.currentStyle?obj.currentStyle[attribute]:document.defaultView.getComputedStyle(obj,false)[attribute];
}


但是如果這個元素是隱藏(display:none)的,尺寸又是未知自適應的,哪有上面的方法就不行了!因為display:none的元素是沒有物理尺寸的! 悲劇就這樣發生了!

幸好css中還有visibility:hidden,不可見屬性,他和display:none最大的區別就是visibility:hidden有物理尺寸。有物理尺寸就可以通過上面的方法獲取尺寸,但是將display:none改成visibility:hidden后頁面就有一塊空白在那里,即使在你獲取尺寸后在馬上將visibility:hidden改成display:none頁面那部分還是會抖動一下。那么最好的辦法就是將這個隱藏的元素移出屏幕或者脫離文檔流( position: absolute)。這樣似乎非常完美了,但是悲劇又發生了,如果你要再顯示這個元素的時侯這個元素是不可見的,位置也不對,因為這是這個元素visibility:hidden;position: absolute。所以在獲取尺寸后還要將樣式還原回去。就是將position和visibility屬性設回原來的樣式。

這就是js獲取隱藏元素的尺寸基本實現方式,大家有興趣可以看看《精通javascript》這本書上的方法。

我這里也做了個簡單的demo,大家可以看看源代碼:

復制代碼 代碼如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>js獲取隱藏元素的尺寸</title>
<style type="text/css">

</style>
<script type="text/javascript" src="http://www.css88.com/tool/css3Preview/jquery-1.4.2.min.js"></script>
</head>

<body>
 <div id="test_display_block" style="display:none; border:10px solid #CDCDCD; margin-left: 100px">這是test容器,可見容器<br />這是test容器,可見容器<br />這是test容器,可見容器<br />這是test容器,可見容器<br />這是test容器,<br />這是test容器,<br />這是test容器,<br />這是test容器,<br />這是test容器,<br /></div>
 <div id="test_display_none" style="display:none; border:10px solid #CDCDCD">這是test容器,這是test容器,<br />這是test容器,<br />這是test容器,<br />這是test容器,<br />這是test容器,<br />這是test容器,<br /></div>
        <div id="test_display_click">點我</div>
        <script type="text/javascript">
            //判斷對象類型
 function getType(o){
            var _t;
            return ((_t = typeof(o)) == "object" ? o==null && "null" || Object.prototype.toString.call(o).slice(8,-1):_t).toLowerCase();
        }
        //獲取元素樣式
 function getStyle(el, styleName) {
            return el.style[styleName] ? el.style[styleName] : el.currentStyle ? el.currentStyle[styleName] : window.getComputedStyle(el, null)[styleName];
        }
 function getStyleNum(el, styleName) {
            return parseInt(getStyle(el, styleName).replace(/px|pt|em/ig,''));
        }
 function setStyle(el, obj){
  if (getType(obj) == "object") {
   for (s in obj) {
    var cssArrt = s.split("-");
    for (var i = 1; i < cssArrt.length; i++) {
     cssArrt[i] = cssArrt[i].replace(cssArrt[i].charAt(0), cssArrt[i].charAt(0).toUpperCase());
    }
    var cssArrtnew = cssArrt.join("");
    el.style[cssArrtnew] = obj[s];
   }
  }
  else
   if (getType(obj) == "string") {
    el.style.cssText = obj;
   }
 }
 function getSize(el) {
        if (getStyle(el, "display") != "none") {
            return { width: el.offsetWidth || getStyleNum(el, "width"), height: el.offsetHeight || getStyleNum(el, "height") };
        }
        var _addCss = { display: "", position: "absolute", visibility: 'hidden' };
        var _oldCss = {};
        for (i in _addCss) {
            _oldCss[i] = getStyle(el, i);
        }
 setStyle(el, _addCss);
        var _width = el.clientWidth || getStyleNum(el, "width");
        var _height = el.clientHeight || getStyleNum(el, "height");
        for (i in _oldCss) {
            setStyle(el, _oldCss);
        }
        return { width: _width, height: _height };
    } 
var dd=document.getElementById("test_display_block");  
alert(getSize(dd).height);
document.getElementById("test_display_click").onclick=function(){
 dd.style.display="block";
        document.getElementById("test_display_none").style.display="block";
}
alert($("#test_display_none").height());
 </script>
</body>
</html>

題外話:一般js的框架,庫都已經封裝了這個方法,比如jQ,我們可以直接使用 height()和width()方法獲取隱藏元素的尺寸。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美精品第一页在线播放| 久久亚洲精品一区二区| 在线午夜精品自拍| 国产美女主播一区| 日韩欧美在线视频免费观看| 中文字幕日韩在线观看| 欧美性生交xxxxx久久久| 亚洲电影免费观看高清| 欧美日韩成人在线播放| 久久久久久久影院| 成人免费看黄网站| 欧美激情在线有限公司| 久久视频在线视频| 欧美孕妇孕交黑巨大网站| 久久久999成人| 欧美精品激情blacked18| 国产经典一区二区| 午夜欧美大片免费观看| 亚洲人精选亚洲人成在线| 亚洲精品xxx| 国产精品精品视频一区二区三区| 亚洲国产成人一区| 欧美精品性视频| 国产色婷婷国产综合在线理论片a| 久久6免费高清热精品| 91免费电影网站| 欧美一级视频在线观看| 中文亚洲视频在线| 日本欧美国产在线| 日韩经典一区二区三区| 欧美综合激情网| 国产亚洲精品久久久久久777| 日韩欧美精品中文字幕| 91成人福利在线| 国产精品久久久| 国内精品久久久久影院优| 精品日韩美女的视频高清| 亚洲三级免费看| 欧美精品久久久久久久久| 国产午夜精品全部视频在线播放| 国产日韩欧美在线播放| 成人黄色生活片| 成人黄色影片在线| 91精品啪aⅴ在线观看国产| 国产一区欧美二区三区| 国产成人精品最新| 亚洲va电影大全| 亚洲加勒比久久88色综合| 国产精品中文字幕在线| 欧美午夜宅男影院在线观看| 亚洲欧美精品中文字幕在线| 国产国产精品人在线视| 高清一区二区三区四区五区| 自拍偷拍亚洲一区| 国产精品∨欧美精品v日韩精品| 国产成人精品优优av| 欧美视频在线观看免费| 亚洲影院色无极综合| 亚洲新中文字幕| 亚洲码在线观看| 黄色精品一区二区| 国产91精品最新在线播放| 亚洲电影在线观看| 日韩精品在线第一页| 日韩中文字幕不卡视频| 亚洲视频在线免费观看| 国产一区二区美女视频| 欧美日本中文字幕| 激情懂色av一区av二区av| 最新国产精品拍自在线播放| 欧美视频在线免费看| 97在线看免费观看视频在线观看| 国产精品久久久久久久一区探花| 亚洲美女久久久| 免费不卡欧美自拍视频| 国产成人综合精品在线| 亚洲欧洲在线免费| 国产亚洲欧洲高清| 久久免费成人精品视频| 国产亚洲aⅴaaaaaa毛片| 亚洲国产精品嫩草影院久久| 精品无人国产偷自产在线| 久久久久久91香蕉国产| 亚洲a中文字幕| 日韩久久精品电影| 国产精品视频永久免费播放| 伊人男人综合视频网| 久久成人这里只有精品| 国产欧美亚洲视频| 亚洲网站视频福利| 成人激情在线播放| 日韩性生活视频| 久久久人成影片一区二区三区| 国产精品96久久久久久又黄又硬| 亚洲激情在线视频| 欧美日韩国产麻豆| 久久99精品久久久久久青青91| 久久国产加勒比精品无码| 三级精品视频久久久久| 欧美精品国产精品日韩精品| 亚洲人成电影网站色| 国产精品h片在线播放| www高清在线视频日韩欧美| 国产在线精品一区免费香蕉| 精品久久久一区| 欧美成人在线免费视频| 亚洲欧美日韩在线高清直播| 亚洲视频axxx| 久久久精品美女| 日韩欧美中文在线| 久久久之久亚州精品露出| 亚洲毛茸茸少妇高潮呻吟| 日韩中文在线视频| 色综合老司机第九色激情| 亚洲国产精品系列| 国产亚洲一区二区精品| 精品国产一区二区三区久久狼黑人| 91亚洲精品久久久久久久久久久久| 日韩二区三区在线| 国产日韩欧美中文| 欧美尤物巨大精品爽| 中文字幕日韩在线视频| 色妞欧美日韩在线| 亚洲人av在线影院| 美女视频黄免费的亚洲男人天堂| 久久久久久久久久久久久久久久久久av| 亚洲欧美日韩一区二区三区在线| 久久久久久久久久久网站| 综合国产在线观看| 欧美成人高清视频| 91免费人成网站在线观看18| 久久五月天色综合| 久久久噜久噜久久综合| 2024亚洲男人天堂| 日韩成人激情视频| 91久久久久久久一区二区| 在线视频精品一| 福利微拍一区二区| 亚洲国产精品va在线看黑人| 日韩欧美综合在线视频| 日本中文字幕久久看| 91高潮在线观看| 国产精品99久久久久久人| 日韩女优人人人人射在线视频| 成人激情电影一区二区| 亚洲福利视频免费观看| 海角国产乱辈乱精品视频| 高清视频欧美一级| 日韩中文在线视频| 中文字幕在线看视频国产欧美| 国产成人精品一区| 日韩在线播放av| 81精品国产乱码久久久久久| 欧美一级视频免费在线观看| 亚洲电影免费观看高清完整版在线| 精品欧美激情精品一区| 日韩精品中文字幕视频在线| 热久久免费国产视频| 久久久国产在线视频| 精品国产精品自拍| 久久久综合免费视频| 色777狠狠综合秋免鲁丝| 亚洲精品日韩激情在线电影| 亚洲网站视频福利|