css控制div显示/隐藏方法及2种方法比较原码 转

本文详细解释了CSS中display和visibility属性的区别。display用于彻底隐藏元素并释放其所占空间;visibility则使元素不可见但仍保留空间。通过示例代码演示了两种属性的实际效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转自http://blog.youkuaiyun.com/czf164

"

CSS中的display和visibility

css中display和visibility语法,他们都可以隐藏和显示html元素。看齐来他们很相似,所以很多人还是会搞错。
谈们的属性分别如下:

display:none|block;
display:none;时隐藏该html元素,确切的说,是在浏览器中消除该元素,不占屏幕的空间。若其下有其他元素,就会上移到该空间区域(好像桌子上有100块钱,现在我把它放在抽屉里藏起来,桌子上放100钱的地方可以放在其他任何东西)。
dispaly:block;显示已经隐藏的html元素,如果别的元素占有了该空间时,他将下移,空间重新别原来的元素占有。(把100块钱重新从抽屉里那出来放回桌子上)

visibility:hidden|visible;
visibility:hidden;隐藏该元素,正真的隐藏,但他还占有那块空间。这时,(桌子上有100块钱,这是我盖了桌布把他隐藏起来,钱还在那里)。
visibility:visible;让元素显示(拿掉了桌布,看到了100块钱)。

接下来用代码来举个例子,代码:


  
< html >
< head >
< script type ="text/javascript" >
function testDisplay()
{
var divD = document.getElementById( " testD " );
if (divD.style.display == " none " )
{
divD.style.display
= " block " ;
}
else
{
divD.style.display
= " none " ;
}
}

function testVisibility()
{
var divV = document.getElementById( " testV " );
if (divV.style.visibility == " hidden " )
{
divV.style.visibility
= " visible " ;
}
else
{
divV.style.visibility
= " hidden " ;
}
}
</ script >
</ head >
</ body >
< div id ="testD" style ="border:#ddd 1px solid" >
< div style ="display:block;border:#ccc 2px solid" >
< div style ="visibility:visible;border:#aaa 2px solid" >
Display
</ div >
</ div >
</ div >
< div id ="testV" style ="border:#ddd 1px solid" >
< div style ="display:block;border:#ccc 2px solid" >
< div style ="visibility:visible;border:#aaa 2px solid" >
Visibility
</ div >
</ div >
</ div >
< input type ="button" value ="TestDisplay" onclick ="testDisplay()" />
< input type ="button" value ="TestVisibility" onclick ="testVisibility()" />
</ body >
</ html >


运行一下框中的代码就可以看到,当testD隐藏时,里面所有的框都隐藏,而且下面的divV和按钮都上移,而当divV隐藏的时候,只有他自己隐藏了,里面的其他元素都没有隐藏。(这里主要是把里面的div元素style属性设置为display和visible,如果去掉也会隐藏,但是,按钮还是不会上移,可以试一下。)

"

转载于:https://www.cnblogs.com/ndxsdhy/archive/2011/04/12/2013472.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值