css控制元素隐藏和显示(css如何设置隐藏和显示)

在CSS中很多隐藏元素的方法,但这些方法的可访问性、布局、动画、性能和事件处理的方式有所不同。

  • 动画: 一些CSS隐藏元素的方法一般是全有或者全无,元素要么是完全可见,要么是完全不可见,并且没有中间状态。其他的,比如透明度,可以是一个范围的值,所以在这中间过程插入动画成为可能;
  • 可访问性: 下面的每一种方法都会在视觉上隐藏一个元素,但不一样会真正的去除DOM元素。有一些方式隐藏元素后,屏幕阅读器仍然能读取到元素内容;
  • 事件处理: 隐藏元素之后,有些方式元素上的事件仍然能被触发,而有些方式就会导致元素上的事件触发无效;
  • 表现: 浏览器加载并解析 HTML DOM 和 CSS 对象模型后,页面将分三个阶段呈现:布局(生成每个元素的几何位置)、绘制(绘制每个元素的像素)、组合(以适当的顺序放置元素层)。仅导致构图变化的效果明显比影响布局的效果更好。在某些情况下,浏览器还可以使用硬件加速。

下面就来看看CSS中隐藏元素的方式,以及每种方式的优缺点。

1. opacity 和 filter: opacity()

opacity: N 和 filter: opacity(N) 属性可以传递一个 0 到 1 之间的数字,或者 0% 和 100% 之间的百分比,对应地表示完全透明和完全不透明。

  • opacity: N:该属性用来设置元素的透明度;
  • filter: opacity(N) :filter属性用来设置元素的滤镜,opacity是滤镜重的透明度,用来设置元素的透明度。
div {
    opacity: 0;
}

div {
    filter: opacity(0%);
}
复制代码

在现代浏览器中,这两者之间几乎没有实际的区别,但如果同时应用多种效果(模糊、对比度、灰度等)时,应该使用 filter 属性。

注意:opacity 可以设置动画并提供出色的性能,但页面上保留完全透明的元素可能会触发事件。

2. color alpha 透明度

可以将元素的color、background-color 和 border-color 等属性设置为rgba(0,0,0,0),这样就会使元素完全透明:

div {
    color: rgba(0,0,0,0);
  background-color: rgba(0,0,0,0);
}
复制代码

这三个属性都是支持设置动画效果的,需要注意,透明度不能应用于带有背景图片的元素,除非它们是使用 linear-gradient 或类似方法生成的。

Alpha 通道可以设置为:

  • transparent:完全透明(中间不能插入动画);
  • rgba(r, g, b, a):红色、绿色、蓝色和 alpha;
  • hsla(h, s, l, a):色相、饱和度、亮度和 alpha;
  • #RRGGBBAA 或 #RGBA。

3. transform

transform 属性可以用于元素的平移、缩放、旋转或倾斜等。可以使用 scale(0) 或者 translate(-9999px, 0px) 属性值来将元素隐藏:

div {
    transform: scale(0);
}

div {
    translate(-9999px, 0px)
}
复制代码

transform 属性提供了出色的性能和硬件加速,因为元素被有效地移动到了单独的层中,并且可以在 2D 或 3D 中进行动画处理。原始的布局空间会保持原样,并不会受影响。使用这种方式隐藏的元素不会触发任何事件。

4. clip-path

clip-path 属性可以创建一个剪辑区域,用于确定元素的哪些部分是可见的。使用 clip-path: circle(0) 可以将元素进行隐藏。

div {
    clip-path: circle(0);
}
复制代码

clip-path为添加动画效果提供了空间,不过它只能在现代浏览器中使用。

5. visibility: hidden

visibility 属性可以设置为 visible 或 hidden 来显示和隐藏元素。

div {
    visibility: hidden;
}
复制代码

除非使用collapse值,否则元素使用的空间保持不变。

6. display: none

display 可能是最常用的元素隐藏方法; 。当其值为 none 时元素就隐藏了。被隐藏的元素不会在页面中占据位置,也不会响应绑定的监听事件。

div {
  display: none;
}
复制代码

然而,在大多数情况下,display 可能是最糟糕的 CSS 属性。除非使用 position:absolute 将元素移出文档流,或者采用contain属性,否则它的隐藏过程无法设置动画,并将触发页面重新布局。

7. z-index

可以通过将元素的 z-index 属性设置为负值,以实现元素的隐藏。这实际上就是将元素放在了我们看不到的层。

div {
  z-index: -1;
}
复制代码

8. position

position属性允许使用top、bottom、left、right 从页面中的默认位置移动元素。因此,绝对定位的元素可以通过左键:-9999px 等值移出屏幕:

div {
  position: absolute;
  left: -999px;
}
复制代码

9. 覆盖另一个元素

通过在元素的上面放置与背景颜色相同的元素,可以在视觉上隐藏一个元素。下面来使用::after伪元素来实现:

div::after {
  position: absolute;
  content: '';
  top: 0;
  bottom: 100%;
  left: 0;
  right: 0;
  background-color: #fff;
}
复制代码

虽然这从技术上讲是可以实现的,但是这样做需要更多的代码。

10. 缩小尺寸

可以通过使用width、height、padding、border-width 或 font-size 来缩小元素的尺寸以实现元素的隐藏。可能还需要应用 overflow: hidden; 来确保内容不会溢出。

div {
  height: 0;
  padding: 0;
  overflow: hidden;
}
复制代码

使用这种形式我们可以在隐藏过程中使用动画效果,并且他的性能会比 transform 好很多。

分类:

(0)

相关推荐

  • 如何隐藏Q龄?怎么设置隐藏QQ龄?

    Q龄以注册qq时间长短算的,会显示在个人资料卡上.但我们不想让它显示,那如何设置呢?怎么设置隐藏QQ龄? 操作方法 01 登陆qq,点击头像查看个人资料卡 02 在资料卡的右侧有个权限设置,点击&qu ...

  • css控制比较div显示/隐藏方法的2种方法

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

  • 如何使用css控制div

    div是html中的块级元素,而css是样式,通过css样式可以对div进行布局. 操作方法 01 打开Dreamweaver软件,新建一个html页面,保存成为html. 02 在body中进行书写 ...

  • CSS控制文本自动换行

    做网页的时候,我们很经常碰到文本的显示,通常来说,文本太长就会很难看.在这里,我们可以用CSS控制文本自动换行.下面是几种强制文本华航的方法. 操作方法 01 方法一:你定死表格的宽度,即给表格一个宽 ...

  • css给图片添加阴影效果(css文字阴影效果怎么设置)

    使用CSS3,你可以为文本和元素添加阴影.一.浏览器支持表中的数字指定完全支持该属性的第一个浏览器版本.数字后面的 -webkit- 或者 -moz- 使用时需要指定前缀.属性ChromeFirefo ...

  • 通过注册表显示XP系统下隐藏的用户

      通过注册表显示XP系统下隐藏的用户 1.打开注册表:开始->运行->regedit.msc.(在注册表的默认情况下,我们是不能看到隐藏用户.) 2.在默认情况下.隐藏用户的查看是隐藏的 ...

  • Win8.1右下角图标设置始终显示后被自动隐藏的解决方法

    一位网友在使用Windows 8.1系统时出现这样一个问题,就是设置了始终显示图标和通知,过一会就自动变成隐藏了。而且这问题并不是由第三方输入法或者star8引起的。下面小编来讲讲该如何解决这个问题。 ...

  • 怎么设置在Win10任务栏通知区域(系统托盘)显示所有图标(不再隐藏图标)

    Windows系统屏幕右下角任务栏最右侧的区域被称为通知区域或系统托盘,会显示音量.网络.输入法.时间等系统图标,另外某些程序的窗口最小化或隐藏后会在这里显示一个图标.为了节省空间,系统图标以外的其它 ...

  • word怎么设置隐藏显示文字呢?

    word中我们需要隐藏一些文字不让别人看到,可以通过字体格式进行设置,当然如果你想看到自己隐藏的文字,你可以设置隐藏的文字为可视状态.下面小编就为大家介绍word怎么设置隐藏显示文字方法,来看看吧! ...

  • excel中设置隐藏列 显示隐藏列的具体操作步骤

    EXCEL是我们日常工作中最常用的软件之一了,在excel中我们还可以隐藏列,隐藏之后还可以设置重新显示,那么具体操作步骤是什么呢?接下来就跟着小编一起来看一下吧.具体如下:1. 第一步在打开的exc ...