CSS属性,Display与Visibility的不同

来源:互联网 发布:Js 中isinfinite() 编辑:程序博客网 时间:2024/05/07 23:55

visibility属性用来确定元素是显示还是隐藏,这用visibility="visible|hidden"来表示,visible表示显示,hidden表示隐藏。当visibility被设置为"hidden"的时候,元素虽然被隐藏了,但它仍然占据它原来所在的位置。例:

<script language="JavaScript">
function toggleVisibility(me){
if (me.style.visibility=="hidden"){
   me.style.visibility="visible";
   }
else {
   me.style.visibility="hidden";
   }
}
</script>


<div onclick="toggleVisibility(this)" style="position:relative">-->click it!<--</div>
第一行文本将会触发"hidden"和"visible"属性,注意第二行的变化。visibility会保留元素的位置,所以第二行不会移动.

----------效果
-->click it!<--
第一行文本将会触发"hidden"和"visible"属性,注意第二行的变化。visibility会保留元素的位置,所以第二行不会移动.

---------点击以后效果

第一行文本将会触发"hidden"和"visible"属性,注意第二行的变化。visibility会保留元素的位置,所以第二行不会移动.

注意到,当元素被隐藏之后,就不能再接收到其它事件了,所以在第一段代码中,当其被设为"hidden"的时候,就不能再接收响应到事件了,因此也就无法通过鼠标点击第一段文本令其显示出来。
另一方面,display属性就有一点不同了。visibility属性是隐藏元素但保持元素的浮动位置,而 display实际上是设置元素的浮动特征。当display被设置为block(块)时,容器中所有的元素将会被当作一个单独的块,就像< div>元素一样,它会在那个点被放入到页面中。(实际上你可以设置<span>的display:block,使其可以像< div>一样工作。将display设置为inline,将使其行为和元素inline一样---即使它是普通的块元素如<div>,它也将会被组合成像<span>那样的输出流。最后是display被设置:none,这时元素实际上就从页面中被移走,它下面所在的元素就会被自动跟上填充。下面看我实例的代码和效果:

例:

<script language="JavaScript">
function toggleDisplay(me){
   if (me.style.display=="block"){
    me.style.display="inline";
    alert("文本现在是:'inline'.");
    }
   else {
    if (me.style.display=="inline"){
     me.style.display="none";
     alert("文本现在是:'none'. 3秒钟后自动重新显示。");
     window.setTimeout("blueText.style.display='block';",3000,"JavaScript");
     }
    else {
     me.style.display="block";
     alert("文本现在是:'block'.");
     }
    }
   }
</script>


<div>在<span id="blueText" onclick="toggleDisplay(this)"
style="color:blue;position:relative;cursor:hand;">蓝色</span>文字上点击来查看效果.</div>

效果:
--------->display:none
蓝色在文字上点击来查看效果.

--------->display:inline

蓝色
文字上点击来查看效果.

--------->display:block
在蓝色文字上点击来查看效果.


至于Display与Visibility性能分析

在CSS规范中有一个渲染对象的概念,通常用一个盒子(box, rectangle)来表示。mozilla通过一个叫frame的对象对盒子进行操作。frame主要的动作有三个:

构造frame, 以建立对象树(DOM树)
reflow, 以确定对象位置,或者是调用mozilla的Layout(这里是指源码的实现)
绘制,以便对象能显示在屏幕上
总的来说,reflow就是载入内容树(在HTML中就是DOM树)和创建或更新frame结构的响应的一种过程。

要提高页面性能,其实就是避免reflow的开销。那么,有哪些方面是需要reflow的呢?比如,未指定图片宽高的话,图片的载入会使页面 reflow, 因为要根据图片宽高来更新frame。这里就有一个提高页面性能的小技巧:如果事先能够确定图片宽高的话,最好在HTML里写上。

在编写一些常见的动态效果时,一般使用CSS的display来切换可见性。很不幸,这也会产生reflow. 把元素置为display:none,相当于把这个元素的frame销毁了,再置回非none时,需要重新构造frame,这就产生了reflow. 而另外一个切换可见性的属性visibility则不存在reflow问题,置为visibility:hidden的元素的frame并没有销毁,需要显示的时候其实就是一个绘制(上面提到的动作第三步)过程而已,没有reflow,因此效率会更高。如果你看过一些JavaScript库/框架的源码,会发现它们大量使用visibility而不是display,道理应该如此。

原创粉丝点击