display:none和visibility:hidden的区别?

css控制元素不可见的方法 { display: none; /* 不占据空间,没法点击 */ }css

/********************************************************************************/css3

{ visibility: hidden; /* 占据空间,没法点击 */ }web

/********************************************************************************/spa

{ position: absolute; top: -999em; /* 不占据空间,没法点击 */ }orm

/********************************************************************************/继承

{ position: relative; top: -999em; /* 占据空间,没法点击 */ }ci

/********************************************************************************/it

{ position: absolute; visibility: hidden; /* 不占据空间,没法点击 */ }io

/********************************************************************************/form

{ height: 0; overflow: hidden; /* 不占据空间,没法点击 */ }

/********************************************************************************/

{ opacity: 0; filter:Alpha(opacity=0); /* 占据空间,能够点击 */ }

/********************************************************************************/

{ position: absolute; opacity: 0; filter:Alpha(opacity=0); /* 不占据空间,能够点击 */ }

}

{ zoom: 0.001; -moz-transform: scale(0); -webkit-transform: scale(0); -o-transform: scale(0); transform: scale(0); /* IE6/IE7/IE9不占据空间,IE8/FireFox/Chrome/Opera占据空间。都没法点击 */ }

/********************************************************************************/

{ position: absolute; zoom: 0.001; -moz-transform: scale(0); -webkit-transform: scale(0); -o-transform: scale(0); transform: scale(0); /* 不占据空间,没法点击 */ }

 

最经常使用的为display:none和visibility:hidden

dispaly:none 设置该属性后,该元素下的元素都会隐藏,占据的空间消失。

visibility:hidden 设置该元素后,元素虽然不可见了,可是依然占据空间的位置。

 

display:none和visibility:hidden的区别?

1.visibility具备继承性,其子元素也会继承此属性,若设置visibility:visible,则子元素会显示

2.visibility不会影响计数器的计算,虽然隐藏掉了,可是计数器依然继续运行着。

3.在css3的transition中支持visibility属性,可是不支持display,由于transition能够延迟执行,所以配合visibility使用纯css实现hover延时显示效果能够提升用户体验

4. display:none会引发回流(重排)和重绘 visibility:hidden会引发重绘 拓展明日每日一题:什么是回流(重排 reflow)?什么是重绘(repaint)?有什么区别?

 

 

拓展明日每日一题:什么是回流(重排 reflow)?什么是重绘(repaint)?有什么区别?

相关文章
相关标签/搜索