在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 好很多。

最后还赠送一份前端大礼包送给大家【加君羊:581286372】帮助大家更好的学习!

在 CSS 中隐藏元素的 10 种方法相关推荐

  1. 5种css隐藏元素的方法_在CSS中隐藏元素的10种方法

    5种css隐藏元素的方法 There are multiple ways to hide an element in CSS, but they differ in the way they affe ...

  2. html隐藏元素hidden,CSS中隐藏元素的几种方法

    几种方法的简单介绍 display:none 最常用的隐藏元素的方法 .hidden{ display:none } 将元素设置为display:none后,元素在页面上将彻底消失,元素本来占有的空间 ...

  3. 【javascript基础——系列10】js中隐藏元素的几种方法以及代码

    系列文章 [javascript基础--系列1]前端页面ajax连接后台服务器传输数据 [javascript基础--系列2]前端页面axios连接后台服务器传输数据 [javascript基础--系 ...

  4. CSS中隐藏内容的3种方法及属性值

    在制作网页时,隐藏内容也是一种比较常用的手法,它的作用一般有:隐藏文本/图片.隐藏链接.隐藏超出范围的内容.隐藏弹出层.隐藏滚动条.清除错位和浮动等等. 使用CSS即可使以上提到的内容隐藏起来,几种隐 ...

  5. html中隐藏元素的几种方法

    1.  display:none  隐藏元素. 在隐藏之后就不再占据空间了. 2. opacity:0  设置图片透明度为0,隐藏元素.  隐藏之后还占据原来的位置 3. height:0;ovrfl ...

  6. css隐藏元素 触发点击事件,css隐藏元素的几种方法中可以触发点击事件的是?...

    css隐藏元素的几种方法中可以触发点击事件的是 是opacity设置为0的方法. css隐藏元素的方式: 1.display:none;.box{ display: none; } 最简单也最粗暴的方 ...

  7. html 隐藏元素点击事件,css隐藏元素的几种方法中可以触发点击事件的是?

    css隐藏元素的几种方法中可以触发点击事件的是 是opacity设置为0的方法. css隐藏元素的方式: 1.display:none;.box{ display: none; } 最简单也最粗暴的方 ...

  8. css隐藏元素的几种方法与区别

    css隐藏元素的几种方法与区别 一:display:none;隐藏不占位 display 除了不能加入 CSS3 动画豪华大餐之外,基本效果卓越,没什么让人诟病的地方.二:position:absol ...

  9. 前端html隐藏元素方式,CSS 隐藏元素的八种方法

    前言 总括: 本文详细讲述了在网页中用CSS隐藏元素的七种方法. 念念不忘,必有回响;有一口气,点一盏灯. 正文 说起隐藏元素我想每一个前端er都能说起几种,但能说全的我想就不是很多了.博主总结了几种 ...

最新文章

  1. Android之一起制作简易唱片播放器
  2. JAVA入门笔记·JAVA名词及环境搭建
  3. php html class,如何使用HTML span标签的class属性?这里有关于class属性的详解
  4. 七夕|情人节情书指南
  5. 重磅!!kaggle训练, 终于不用怕断网了
  6. python计算函数运行时间表_python计算一段代码的运行时间(类和函数)
  7. setpriority_Java Thread类的最终void setPriority(int priority)方法(带示例)
  8. 五邑大学c语言期末考试题,五邑大学 c语言试卷.doc
  9. YUV采样及存储格式
  10. WindowsBatch与LinuxShell比较[变量符号和关键字]
  11. linux 系统监控、诊断工具之 lsof 用法简介
  12. 非功能需求分析--web开发课内实例
  13. 裤子尺码对照表eur40_裤子尺寸对照表,衣服尺寸对照表,服装尺寸对照表- 尺码对照表...
  14. 5G基站耗电剑指4G基站水平,通过IMT-2020(5G)大会看5G发展趋势
  15. 红蜘蛛显示器测试软件,红蜘蛛5使用displayCAL校准显示器(蓝绿蜘蛛5通用)
  16. 商城项目02_环境搭建、安装VAGRANT、DOCKER、MYSQL、REDIS、从0搭建各个微服务项目、数据库初始化、安装NGINX
  17. 7 索引,视图,同义词,序列,表空间
  18. Android热修复(1):热修复的介绍和原理解析
  19. C#下ECDsa签名、验签
  20. springcloud ribbon实现负载均衡的时候,提示Request URI does not contain a valid hostname: htt...

热门文章

  1. 个人永久性免费-Excel催化剂功能第54波-批量图片导出,调整大小等
  2. 用表情开发“俏皮”编程语言
  3. android 原生等待动画,Android 自定义Loading动画
  4. 深度(穿透)选择器 >>> /deep/ ::v-deep
  5. mysql的sysdate_MySQL获取时间及日期的函数--sysdate()
  6. 云贝餐饮连锁V2 v2.5.6 外卖/店内/预定/排号 餐饮外卖扫码点餐 智慧新零售
  7. 四川黄金深交所上市:年营收5.26亿募资4.3亿 市值43亿
  8. 如何使用php调用打印机驱动程序,网络打印服务器怎么安装和使用?
  9. 空间向量在任意平面的投影公式推导 (矩阵方法)
  10. mysql 安全插件