美文网首页面试那些事
11种css隐藏页面元素的方法

11种css隐藏页面元素的方法

作者: _静夜听雨_ | 来源:发表于2022-10-20 10:57 被阅读0次

面试的时候可能会被问到:隐藏页面元素的方法有哪些?有什么差别?

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

11种实现方式:

1.display: none: 渲染树不会渲染对象

设置元素的display为none是最常用的隐藏元素的方法
.hide { display:none;}
将元素设置为display:none后,元素在页面上将彻底消失
元素本身占有的空间就会被其他元素占有,也就是说它会导致浏览器的重排和重绘
消失后,自身绑定的事件不会触发,也不会有过渡效果
特点:元素不可见,不占据空间,无法响应点击事件

2.visibility: hidden: 元素在页面中仍占据空间,但是不会响应绑定的监听事件。

设置元素的visibility为hidden也是一种常用的隐藏元素的方法
从页面上仅仅是隐藏该元素,DOM结果均会存在,只是当时在一个不可见的状态,不会触发重排,但是会触发重绘
.hidden{ visibility:hidden}
给人的效果是隐藏了,所以他自身的事件不会触发
特点:元素不可见,占据页面空间,无法响应点击事件

3.opacity: 0: 元素在页面中仍然占据空间,并且能够响应元素绑定的监听事件。

opacity属性表示元素的透明度,将元素的透明度设置为0后,在我们用户眼中,元素也是隐藏的
opacity: N 和 filter: opacity(N) 属性可以传递一个 0 到 1 之间的数字,或者 0% 和 100% 之间的百分比,对应地表示完全透明和完全不透明。
opacity: N:该属性用来设置元素的透明度;
filter: opacity(N) :filter属性用来设置元素的滤镜,opacity是滤镜重的透明度,用来设置元素的透明度。
不会引发重排,一般情况下也会引发重绘
如果利用 animation 动画,对 opacity 做变化(animation会默认触发GPU加速),则只会触发 GPU 层面的 composite,不会触发重绘
.transparent { opacity:0;}
由于其仍然是存在于页面上的,所以他自身的的事件仍然是可以触发的,但被他遮挡的元素是不能触发其事件的
需要注意的是:其子元素不能设置opacity来达到显示的效果
特点:改变元素透明度,元素不可见,占据页面空间,可以响应点击事件
在现代浏览器中,这两者之间几乎没有实际的区别,但如果同时应用多种效果(模糊、对比度、灰度等)时,应该使用 filter 属性。
注意:opacity 可以设置动画并提供出色的性能,但页面上保留完全透明的元素可能会触发事件。

4.position: absolute: 通过使用绝对定位将元素移除可视区域内,以此来实现元素的隐藏。

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

5.z-index: 负值:来使其他元素遮盖住该元素,以此来实现隐藏。

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

6.clip/clip-path: 元素仍在页面中占据位置,但是不会响应绑定的监听事件。

通过裁剪的形式
.hide { clip-path: polygon(0px 0px,0px 0px,0px 0px,0px 0px);}
特点:元素不可见,占据页面空间,无法响应点击事件

7.transform: scale(0,0): 将元素缩放为 0,元素仍在页面中占据位置,但是不会响应绑定的监听事件。

  1. 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。

  1. 可以通过使用width、height、padding、border-width 或 font-size 来缩小元素的尺寸

可以通过使用width、height、padding、border-width 或 font-size 来缩小元素的尺寸以实现元素的隐藏。可能还需要应用 overflow: hidden; 来确保内容不会溢出。
div { height: 0; padding: 0; overflow: hidden;}
使用这种形式我们可以在隐藏过程中使用动画效果,并且他的性能会比 transform 好很多。
.hiddenBox { margin:0; border:0; padding:0; height:0; width:0; overflow:hidden;}
特点:元素不可见,不占据页面空间,无法响应点击事件

  1. 覆盖另一个元素

通过在元素的上面放置与背景颜色相同的元素,可以在视觉上隐藏一个元素。下面来使用::after伪元素来实现:
div::after { position: absolute; content: ''; top: 0; bottom: 100%; left: 0; right: 0; background-color: #fff;}
虽然这从技术上讲是可以实现的,但是这样做需要更多的代码。

  1. transform 属性可以用于元素的平移、缩放、旋转或倾斜等。

transform 属性可以用于元素的平移、缩放、旋转或倾斜等。可以使用 scale(0) 或者 translate(-9999px, 0px) 属性值来将元素隐藏:
div { transform: scale(0);}div { translate(-9999px, 0px)}
transform 属性提供了出色的性能和硬件加速,因为元素被有效地移动到了单独的层中,并且可以在 2D 或 3D 中进行动画处理。原始的布局空间会保持原样,并不会受影响。使用这种方式隐藏的元素不会触发任何事件。

小结
最常用的还是display:none和visibility:hidden,其他的方式只能认为是奇招,它们的真正用途并不是用于隐藏元素,所以并不推荐使用它们

区别
关于display: none、visibility: hidden、opacity: 0的区别,如下表所示:

image.png

相关文章

  • CSS隐藏页面元素的方法

    .hide-opacity{opacity:0;}复制代码 通过下面的gif图,我们可以总结opacity隐藏元素...

  • jquery 动画特效

    隐藏元素的hide方法 让页面上的元素不可见,一般可以通过设置css的display为none属性。但是通过css...

  • css隐藏页面元素

    Opacity opacity属性的意思是设置一个元素的透明度。它不是为改变元素的边界框(bounding box...

  • jQuery动画篇

    jQuery中隐藏元素的hide方法 让页面上的元素不可见,一般可以通过设置css的display为none属性。...

  • 用 CSS 隐藏页面元素的 4 种方法

    用 CSS 隐藏页面元素有许多种方法。你可以将opacity设为0、将visibility设为hidden、将di...

  • 总结 CSS 隐藏页面元素的一些方法

    先把css隐藏页面元素有几种方法列出来,方便查看以及使用,下文再分析其中的原理 display : none ; ...

  • css隐藏页面元素的几种方法

    用css隐藏页面元素有很多种方法。在平时的开发中,主要使用以下几种: display的值设为none opacit...

  • 第 7 章 jQuery 动画特效

    调用 show() 和 hide() 方法显示和隐藏元素 show()和hide()方法用于显示或隐藏页面中的元素...

  • CSS元素隐藏

    一、CSS元素隐藏 在CSS中,让元素隐藏(指屏幕范围内肉眼不可见)的方法很多,有的占据空间,有的不占据空间; ...

  • 如何使用css隐藏元素

    2019-03-15-11:50:于公司 一、CSS元素隐藏在CSS中,让元素隐藏(指屏幕范围内肉眼不可见)的方法...

网友评论

    本文标题:11种css隐藏页面元素的方法

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