美文网首页
CSS元素隐藏

CSS元素隐藏

作者: studystudy | 来源:发表于2017-10-15 21:34 被阅读0次

    一、CSS元素隐藏

      在CSS中,让元素隐藏(指屏幕范围内肉眼不可见)的方法很多,有的占据空间,有的不占据空间;   有的可以响应点击,有的不能响应点击。一个一个看。

    代码如下:

    { display: none; /* 不占据空间,无法点击 */ }

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

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

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

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

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

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

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

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

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

    { 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

    目前,我所知道的不同有三点(欢迎补充):

    1.空间占据(display:none不占据空间,visibility:hidden仍占据空间。)

    2.回流与渲染(display:none隐藏产生reflow和repaint(回流与重绘),而visibility:hidden没有这个影响前端性能的问题。)

    3.株连性

    第三点估计是不少同行不知道的,就是“株连性”方面的差异。

    所谓“株连性”,就是如果祖先元素遭遇某祸害,则其子子孙孙无一例外也要遭殃。display:none就是“株连性”明显的声明:一旦父节点元素应用了display:none,父节点及其子孙节点元素全部不可见,而且无论其子孙元素如何不屈地挣扎都无济于事。

    在实际的web应用中,我们要经常实现一些显示隐藏的功能,由于display:none本身特性以及jQuery潜在的驱动,使得我们对display:none这种隐藏特性相当熟知。因此,久而久之会形成比较牢固的情感化认识,并无法避免地将这种认识迁移到其他类似表现属性(eg. visibility)的认识上,再加上一些常规经验……

    举例来说吧,通常情况下,我们给一个父元素应用visibility:hidden,则其子孙后代也都会全部不可见。于是,我们就会有类似的认识迁移:应用了visibility:hidden声明下的子孙元素如何不屈地挣扎都摆脱不了不可见被抹杀的命运。而实际上却存在隐藏“失效”的情况。

    何时隐藏“失效”?很简单,如果子孙元素应用了visibility:visible,那么这个子孙元素又会刘谦般地显现出来。

    visibility就是这样一个funny的属性。

    三。

    隐藏文本

    隐藏网页元素的方法有很多,比如设置display:none,或是使用全透明(opacity)。在设置文本的时候,有时并不希望文本丢失,而通常是把文字转移到屏幕外面,浏览器是可以检测到的。

    有如下两种隐藏文本的方式:

    1.使用text-indent隐藏:图片替换文本、搜索引擎优化2.使用position进行定位隐藏:利于屏幕讲述工具的阅读

    使用text-indent

    在h1上设置logo为背景并设置居中来做SEO:

    h1{text-indent: -9999px;/*缩进*/margin:0auto;width:100px;height:100px;/*居中*/background:url("img/sf.jpg") no-repeat;}

    使用定位

    p{position: absolute;top: -9999px;left: -9999px; }

    rgba和opacity

    rgba()和opacity都能实现透明效果,但最大的不同是opacity作用于元素,以及元素内的所有内容的透明度,

    而rgba()只作用于元素的颜色或其背景色。(设置rgba透明的元素的子元素不会继承透明效果!)

    ou和ul的列表缩进

    IE使用margin-left来缩进列表,而Safari和Firefox使用padding-left。

    ol,ul{padding-left:40px; }

    而IE的默认样式是:

    ol,ul{margin-left:30px; }

    去除li的左边距,比如:

    ol,ul{padding-left:0px; }

    或者也可以只针对IE进行修复:

    对比总结

    display:none是个相当惨无人道的声明,子孙后代全部搞死(株连性),而且连块安葬的地方都不留(不留空间),导致全体民众哗然(渲染与回流)。

    visibility:hidden则具有人道主义关怀,虽然不得已搞死子孙,但是子孙可以通过一定手段避免(伪株连性),而且死后全尸,墓地俱全(占据空间),国内民众比较淡然(无渲染与回流)。

    相关文章

      网友评论

          本文标题:CSS元素隐藏

          本文链接:https://www.haomeiwen.com/subject/nyzcuxtx.html