display:none和visibility:hidden的差別比較與演示代碼

前言:
在使用css隱藏欄位或物件的時候,
常常會使用到display:none和visibility:hidden這兩個屬性,
但卻很容易分不清楚這兩個的差別,
或是乾脆同時使用兩種屬性,來確保物件一定被隱藏,
其實我們可以很簡單的來區(qū)分兩者的差別。
AD:
你知道CSS display:none和visibility:hidden的區(qū)別嗎,這里和大家分享一下,使用CSS display:none屬性后,HTML元素(對象)的寬度、高度等各種屬性值都將“丟失”;而使用visibility:hidden屬性后,HTML元素(對象)僅僅是在視覺上看不見(完全透明),而它所占據(jù)的空間位置仍然存在。
CSS display:none和visibility:hidden的區(qū)別
visibility:hidden隱藏,但在瀏覽時保留位置;CSS display:none視為不存在,且不加載!
Overflow屬性值{visible|hidden|scroll|auto}前提是先要限制DIV的寬度(width)和高度(height)。二者都是隱藏HTML元素,在視覺效果上沒有區(qū)別,但在一些DOM操作中二者還是有所不同的。
CSS display:none;
使用該屬性后,HTML元素(對象)的寬度、高度等各種屬性值都將“丟失”;
visibility:hidden;
使用該屬性后,HTML元素(對象)僅僅是在視覺上看不見(完全透明),而它所占據(jù)的空間位置仍然存在,也即是說它仍具有高度、寬度等屬性值。
具體區(qū)別請看演示代碼吧:
<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlnshtmlxmlns="http://www.w3.org/1999/xhtml"lang="gb2312">
<head>
<head>
<title>實例演示:CSS display:none和visible:hidden的區(qū)別</title>
<metahttp-equivmetahttp-equiv="content-type"content="text/html;charset=gb2312"/>
<metahttp-equivmetahttp-equiv="content-type"content="text/html;charset=gb2312"/>
<metanamemetaname="author"content="楓巖,CnLei.y.l@gmail.com">
<metanamemetaname="copyright"content="http://www.cnlei.com"/>
</head>
<body>
<p><ahrefahref="javascript:alert($('CnLei_1').innerHTML+'的寬度:\n'
+GetXYWH($('CnLei_1')).W);">點擊這里CSS display:none;</a></p>
<p><ahrefahref="javascript:alert($('CnLei_2').innerHTML+'的寬度:\n'
+GetXYWH($('CnLei_2')).W);">點擊這里visibility:hidden;</a></p>
<dividdivid="CnLei_1"style="CSS display:none;">CnLei_1</div>
<dividdivid="CnLei_2"style="visibility:hidden;">CnLei_2</div>
<scripttypescripttype="text/javascript">
varw3c=(document.getElementById)?true:false;
varagt=navigator.userAgent.toLowerCase();
varie=((agt.indexOf("msie")!=-1)
&&(agt.indexOf("opera")==-1)&&(agt.indexOf("omniweb")==-1));
varie5=(w3c&&ie)?true:false;
varns6=(w3c&&(navigator.appName=="Netscape"))?true:false;
function$(o){
returndocument.getElementById(o)?document.getElementById(o):o;
}
functionGetXYWH(o){
varo=$(o);
varnLt=0;
varnTop=0;
varoffsetParent=o;
while(offsetParent!=null&&offsetParent!=document.body){
nLt+=offsetParent.offsetLeft;
nTop+=offsetParent.offsetTop;
if(!ns6){
parseInt(offsetParent.currentStyle.borderLeftWidth)>0?
nLt+=parseInt(offsetParent.currentStyle.borderLeftWidth):"";
parseInt(offsetParent.currentStyle.borderTopWidth)>0?
nTop+=parseInt(offsetParent.currentStyle.borderTopWidth):"";
}
offsetParentoffsetParent=offsetParent.offsetParent;
}
return{X:nLt,Y:nTop,W:o.offsetWidth,H:o.offsetHeight};
}
</script>
</body>
</html>
實際演練
首先,我們先拉出一個Table如下,
<table id="table1">
<tr>
<td>1
</td>
<td>2
</td>
</tr>
<tr>
<td>3
</td>
<td>4
</td>
</tr>
</table>
執(zhí)行后看起來會像這樣子

首先我們替第二行的 tr 加上 style="visibility:hidden"
<tr style="visibility:hidden">
可以發(fā)現(xiàn)我們的Table會變成這樣

所以當使用 visibility:hidden 時,
物件是確實的被隱藏的,但物件的位置仍舊保持著不會消失
再來我們將第二行的tr改成 style="display:none"
<tr style="display:none">
我們的Table會變成

可以看到第二行連空白也消失了,
所以當使用 style="display:none" 時,
物件連原本所在的位置都一起被隱藏了
總結(jié):
若我們需要把一個物件完全的隱藏,
那我們應(yīng)該要使用 display:none ,
它可以將物件連同所在位置一起隱藏,
就好像真的在網(wǎng)頁上完全消失了,
而實際上JQuery的hide及show也是在透過操作display屬性來實現(xiàn)的,
所以當需要在網(wǎng)頁上預(yù)設(shè)某些物件是隱藏時,
不需要透過jquery一個一個的去寫
相關(guān)文章
IE/火狐/Chrome操作display:none對象所遇問題解答
display:none在IE、火狐、Chrome等主流瀏覽器中的一些問題想必大家也有碰到過吧,接下來為大家詳細圖文介紹下,感興趣的朋友可以參考下哈希望可以幫助到你2013-03-28css元素隱藏原理及display:none和visibility:hidden
在CSS中,讓元素隱藏指屏幕范圍內(nèi)肉眼不可見的方法很多,只不過有的依然保留空間,而有的卻消失的不留痕跡,接下來本文將詳細介紹下css元素隱藏原理,感興趣的你可不要錯過2013-02-27ie9崩潰現(xiàn)象當js設(shè)置tr元素樣式為display:none
在css測試中遇到一個ie9的bug:用js設(shè)置tr元素的樣式為display:none 會引起ie崩潰,很是郁悶,于是網(wǎng)上搜羅一下終于找到了解決方法,曬出來與大家分享,感興趣的你可不要錯2013-02-20IE7下父元素及子元素的隱藏順序不當帶來的display:none出現(xiàn)BUG
IE7下,先隱藏父元素,后隱藏子元素,再顯示父元素,被隱藏的子元素重疊區(qū)域下面, 存在另一個可見的元素,則該display:none的子元素出現(xiàn)BUG;接下來介紹一下發(fā)生經(jīng)過,感興2013-01-19如何通過 display:olck/none 完成一個菜單欄
這篇文章主要介紹了如何通過 display:olck/none 完成一個菜單欄,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-02-18