程序亦非猿

CSS实现隐藏页面的5种方式

2018/06/05 Share

用 Css 隐藏页面也很多方法,你可以讲 opacity 设置为 0、将 visibility 设为 hidden、将 dispaly 设为 none 或者将 position 设为 absolute 然后将位置移动到不可见的区域

你有没有想过为什么我们有这么多技术来隐藏这些元素,而看起来他们实现的效果都是一样的,其实每一种方法和其他的方法之间都有一些细微的不同,这些不同决定了在一些特定的场合下使用哪一种方法,这篇教程将覆盖到那些你需要记住的细小不同点,让你根据不同的情况下,选择使用哪种方法隐藏元素

Opacity

opacity 属性的意识就是设置让一个元素的透明度,它不是为了改变元素的边界框(bounding box) 而设计的,这意味着将 opacity 设置为 0 只能从视觉上隐藏,而元素本身依然占据着它的位置并对网页的布局起作用,它也将相应用户交互

.hide {

opacity: 0;

}

如果你打算使用 opacity 属性在读屏软件中隐藏,很不幸,你并不能如你所愿。元素和它的所有内容会被读屏软件阅读,就像网页上的其他元素那样。换句话说,元素的行为就和它们不透明时一致

我还要提醒一句,opacity 属性可以用来实现一些效果很棒的动画。任何 opacity 属性值小于 1 的元素也会创建一个新的堆叠上下文(stacking context)。

看下面的列子:

@SitePoint 提供的例子“用 opacity 隐藏元素”

当你鼠标移到被隐藏的第 2 个区块上,元素状态平滑地从完全透明变成不透明,区块也将 cursor 属性设置为了 pointer ,这说明用户可以与它交互

Visibility

第二个要说的属性是 Visibility。将它的值设为 hidden 将隐藏我们的元素。如同 opacity 属性,被隐藏的元素依然会对我们的网页布局起作用。与 opacity 唯一不同的是它不会响应用户的任何交互。此外,元素在读屏软件中也会被隐藏。

这个属性也能实现动画效果,只要它的初始的结束状态不一样。这确保了 Visibility 状态切换之间的过渡动画可以是时间平滑的,(事实上可以用这一点来用 hidden 实现元素的延迟显示和隐藏——译者注)。

.hide {

​ visibility: hidden;

}

下面的例子演示了 visibilityopacity 有怎么样的不同:

@SitePoint 提供的例子“用 visibility 隐藏元素”

注意,如果一个元素的 visibility 被设置为 hidden,同时想要显示它的子孙元素,只要将那个元素的 visibility 显示设置为 visible 即可(就如例子里面的 .o-hide p——译者注)。尝试只 hover 在隐藏元素上,不要 hover 在 p 标签里的数字上,你会发现你的鼠标光标没有变成手指头的样子,此时,你点击鼠标,你的 click 时间也不会触发。

而在 <div> 标签里面的 <p> 标签则依然可以捕获所有的鼠标事件。一旦你的鼠标移动到文字上,<div> 本身变得可见并且事件注册也会随之生效

Display

display 属性依照词义真正隐藏元素。将 display 属性设为 none 确保元素不可见并且连盒模型都生成不了,使用这个属性,被隐藏的元素不占任何空间,不仅如此,一旦 display 设为 none,任何对该元素直接打用户交互操作都不能生效。此外,读屏软件也不会读到元素的内容。这种方式产生的效果就像元素完全不存在。

任何这个元素的子孙元素也会被同时隐藏。为这个属性添加过度效果是没有任何效果的,它的任何不同状态值之间的切换总是立即生效

不过注意通过 DOM 依然可以访问到这个元素。因此你可以通过 DOM 来操作它,就像操作其他元素。

.hide{

display: none;

}

看下面的列子:

@SitePoint 提供的例子“用 display 隐藏元素”

你将看到第二个元素内有一个<p> 元素,它有自己的 display 属性被设置成 black,但是它依然不可见。这是 visibility:hiddendisplay:none 的另一个不同之处。在前一个例子里,将任何子孙元素 Visibility 显示设置成 visible 可以让它变得可见,但是 display 不吃这一套,不管自身 display 值是什么,只要祖先 display:none ,它们就都不可见

现在,将鼠标移到第一个块元素上面几次,然后点击它。这个操作将让第二个块元素显现出来,它其中的一个数字将是一个大于 0 的数。这是因为,元素即使设置成对用户隐藏,还是可以通过 JavaScript 来操作的

Position

假设有一个元素它想要与你交互,但是你又不想让它影响你的网页布局,没有合适的属性可以处理这种情况,(opacity 和 visibility 影响布局, display 不影响布局但又无法直接交互——译者注)。在这种情况下,你只能考虑将元素移出可是区域。这个办法既不会影响布局,也能让元素保持可以操作,下面是采用这种办法的 CSS

.hide{

position: absolute;

top: -9999px;

left: -9999px;

}

下面列子阐明了怎样通过绝对定位的方式来隐藏元素,并让他和前面的效果一样:

@SitePoint 提供的例子“用 position 属性隐藏元素”

这种方法是通过元素的 topleft 值设置成绝大负数,来该变元素的位置,使它不可见,采用这个技术的一个好处就是,(或者潜在的缺点)是用它隐藏的元素的内容可以被读屏软件读取。这完全可以理解,是因为你只是将元素移到可视区域外面让用户无法看到它。

你得避免使用这种方法去隐藏任何可以获取焦点的元素,因为如果这么做,当用户获取焦点的时候,会导致一个不可预料的焦点切换,这个方法在创建复选框和单选框按钮时,经常被使用。(用 DOM 模拟复选框和单选按钮,但用这个方法隐藏真正的 checkbox 和 radio 元素来“接收”焦点切换——译者注)

Clip-path

隐藏元素的另一种方法是通过裁剪它们来实现,在以前,这可以通过 clip 属性来实现,但是这个属性被废弃了,换成一个更好的属性叫 clip-path 。Nitish Kumar 最近在 SitePoint 发表了“介绍 clicp-path 属性”这篇文章,通过阅读它可以了解这个属性的更多高级用法。

记住 clip-path 属性还没有在 IE 和 Edge 下被完全支持,如果你要在你的 clip-path 中使用外部的 SVG 文件,浏览器支持还会更低。使用 clip-path 方式如下

.hide{

clip-path: polygon(0px 0px,0px 0px,0px 0px,0px 0px);

}

下面是一个实际使用的列子:

@SitePoint 提供的例子“用 clip-path 属性隐藏元素”

如果你把鼠标悬停在第一个元素上,它依然可以影响第二个元素,尽管第二个元素已经通过 clip-path 隐藏了。如果你点击它,它会移除用来隐藏的 class,让我们的元素从那个位置显现出来。被隐藏元素中的文字仍然能够通过读屏软件读取,许多 WordPress 站点使用 clip-path 或者之前的 clip来实现专门为读屏软件提供的文字。

虽然我们的元素自身不再显示,它也依然占据本该占据的矩形大小,它周围的元素的行为就如同它可见时一样。记住用户交互例如鼠标悬停或者点击在剪裁区域之外也不可能生效。在我们的例子里,剪裁区大小为零,这意味着用户将不能与隐藏的元素直接交互。此外,这个属性能够使用各种过渡动画来实现不同的效果。

总结:

在这篇教程里,我们看了 5 种不同的通过 CSS 隐藏元素的方法。每一种方法都与其他几种有一点区别。知道你想要实现什么有助于你决定采用哪一个属性,随着时间推移,你就能根据实际需求本能地选择最佳方式了。

原文:http://www.zcfy.cc/article/457

CATALOG
  1. 1. Opacity
  2. 2. Visibility
  3. 3. Display
  4. 4. Position
  5. 5. Clip-path
  6. 6. 总结: