将页面元素隐藏的10种方法

news2024/11/22 20:51:17

在Web开发中,隐藏页面元素使其视觉不可见是一个非常常见的需求。为了实现这一目标,我们通常会采用多种方法,最常用的例如CSS的display属性,只要设置为node即可隐藏元素。
本文将通过对当前所有可用的隐藏元素的方法做一个总结,大概有10种方法可以使用,一一做下介绍。

所有方法的总结在文章的最后,可以跳过前文。

display:none

display 属性用于设置页面元素的显示方式,能够控制元素的显示或者隐藏,当它的值被设置为 none 时,就会隐藏对应的元素,使其不可见。
这种方法是最常用的隐藏元素的方法,可以让元素在网页中完全消失,不会占据页面上的任何空间,用户无法看到或进行交互。
但是,这样也会导致元素脱离文档流,可能会影响其他元素的布局。

<div class="elem">
  这是一个要隐藏的元素。
</div>
.elem {
  display: none;
}

visibility:hidden

visibility 属性是专门用于控制元素的显示和隐藏,当它的值设置为 hidden 后,也会将元素隐藏。
但与 display 不同的地方在于,此时元素仍会占据页面上的空间,只是在视觉上不可见,显示为空白区域(所占区域为元素的大小)。
这种方式也是无法进行元素的响应事件监听和交互状态,通常应用于需要隐藏但仍需要占据空间的元素,如占位符、提示信息等。

.elem {
  visibility: hidden;
}

opacity: 0

opacity 属性用于控制元素的透明度,取值范围:0 - 1,0 表示完全透明,1 表示不透明。
当我们将元素的 opacity 属性设置为 0 时,该元素将会变为不可见状态,不过它仍会占据页面上的空间。

.elem {
  opacity: 0;
}

这种方式隐藏的元素,都是视觉上不可见,和 visibility:hidden 比较类似。
但不同的地方在于:opacity: 0 设置元素不可见以后,用户仍然能够与该元素进行交互,而 visibility:hidden 则不行。

.elem {
  opacity: 0;
}
.elem:hover {
  opacity: 0.5;
}
<div class="elem" onclick="alert(1)">
  这是一个要隐藏的元素。
</div>

如上代码所示,div.elem 元素设置 opacity: 0 不可见以后,onclick 鼠标点击事件会响应,hover 状态也会执行。

position

position 属性用于控制元素的定位方式,可以将元素在页面的不同位置进行定位,有多个取值,也是css中非常重要的属性,但我们这里只讨论如何隐藏元素。
position 取值相对定位或者绝对定位时,给定(left/top/right/bottom)四个方向上的任意一个较大的值(或负值),都能将元素设置到屏幕之外,达到不可见的状态。

在使用上,相对定位和绝对定位有一定的区别。
绝对定位的元素会脱离当前文档流,整个从视觉上完全消失,效果上与 display:none 相似。

.elem {
  position: absolute;
  left: -9999px;
}

而相对定位则只是将元素移出,在当前位置仍然会占据一定的空间,效果上与 visibility:hidden 较相似。

.elem {
  position: relative;
  top: -9999px;
}

但使用的定位的方式使元素不可见,都无法再与元素进行交互操作。

在绝对定位时,还可以通过 z-index 属性将元素的层级调低,让它被其他元素遮挡,达到一定的隐藏效果。

clip-path:circle(0%)

clip-path 属性,允许用不同的剪切方式创建元素的可显示区域,区域内的内容可以展示,区域外的内容则隐藏。之前也有博文详细介绍该属性,clip-path详解
根据它的特点,如果将元素的所有内容都设置到显示区域外,则元素就自动隐藏了,达到不可见的状态,而要实现这点只需要剪切区域设置为0,有多个形状值可以实现:

.elem {
  clip-path: circle(0%);
  clip-path: inset(50%);
  clip-path: polygon(0 0);
}

这种方式隐藏的元素,虽然不可见,但仍然会占据自身大小的空间,效果上与 visibility:hidden 相似。并且也不能响应事件监听和各种交互状态。

filter:blur(500px)

filter 属性是CSS3开始提供的,用于对页面元素设置各种滤镜效果,有大概十多个各种不同的滤镜值可以设置,我们这里使用 blur 模糊效果来达到隐藏页面元素的效果。

只需要将 blur() 值设置为一个较大的值,元素将模糊到无法显示的地方,如值大于400:

.elem {
  filter: blur(500px);
}

通过以上代码,就能将元素进行隐藏了,他的效果与使用 opacity: 0 一样,元素虽不可见,但仍占据空间,并且能够响应事件和交互状态。

注意:filter:opacity(0) 透明滤镜与 opacity: 0 也一样。

HTML Element 的 hidden 属性

通过设置页面元素(Element)的 hidden 属性,也能够将元素进行隐藏,它达到的效果与 display:none 几乎一样,元素脱离文档流、不可见,不占用空间,无法响应事件和用户交互等。

<div hidden>这个元素将被隐藏,不占用空间,无法交互。</div>

以上方式,针对的页面元素,是不区分块状元素和行内元素,都能够达到隐藏效果,下面还有几种方式,可能针对特定的元素才起作用。

width: 0

这个方式代表一类隐藏元素的方法,即通过设置元素的宽高属性为 0,达到隐藏元素的效果。
注意,行内元素无法设置宽高属性,所以这种方法一般处理块状元素。

.elem {
  width: 0;
  height: 0;
}

以上代码,就能将块状元素进行隐藏,不占据空间,并且这种方式隐藏的块状元素也无法响应事件和交互状态。

但如果块状元素内包含文字,则文字内容仍然会显示,并且呈竖状:

在这里插入图片描述
因此,这类方法平时很少会使用。
那如果想把文本内容也隐藏,有没有办法呢?那就要用到下面的属性了。

font-size: 0

font-size 用于设置文字的大小,当我们把它的值设置为 0 时,文本内容就不可见。

.elem {
  font-size: 0;
}

如果是行内元素,或者块状元素内只包含文字,则单独使用 font-size: 0 都可以隐藏。
但我们可以结合宽高和文字大小属性一起使用,就能达到完整的隐藏效果,而不分块状元素还是行内元素,都能起作用:

.elem {
  width: 0;
  font-size: 0;
}

这种方式,行内元素将占据空间,而块状元素则不占,都无法进行交互。

transform:scale(0)

transform 属性用于对元素进行变换,例如旋转、缩放、平移等。其中,缩放 scale 就可以用来隐藏元素使用,只需要将 scale 的值设置为 0,该元素就会被缩放到不可见的状态,达到隐藏效果:

.elem {
  transform: scale(0);
}

需要注意的是,transform:scale(0) 达成的隐藏效果,无法作用于行内元素,这是由于 transform 属性本身对行内元素不起作用。
并且,这种隐藏方式也会占用页面空间(元素的原始大小区域),但元素实际上宽高都为0,同样无法响应事件和交互。

其他

以上多数都是通过设置 css 属性达成的页面元素隐藏效果,但在前端开发中,很多时候,我们需要使用 JavaScript 来控制页面元素,包括隐藏也是一样的。
如,我们使用 JavaScript 代码来控制元素的 sdiplay 属性,以便可以隐藏或显示元素:

const element = document.getElementById('elementId')
element.style.display = element.style.display === 'none' ? 'block' : 'none'

以上代码,就是获取到元素对象,通过设置 style 样式对象的 display 属性,控制了它的隐藏和显示。

除此以外,我们还可以使用 JavaScript 对象将页面元素删除,如果要显示还可以再添加回来,通过这种方式也能达成影响和显示的效果:

const element = document.getElementById('elementId')
document.body.removeChild(element)
setTimeout(() => {
  document.body.appendChild(element)
}, 3000)

如上代码所示,我们将元素先通过文档对象的 removeChild 方法进行删除,再定时3秒以后,把该元素添加到文档中,这样,可算是隐藏和显示了。

总结

以上就是关于Web页面隐藏元素的10种方法(除去了JavaScript的方法),每种方法都有自身的特点,我们在实际开发过程中,需要根具体的需求和场景来选择最合适的方法。
下面,是针对这些方法的一个总结:

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/490571.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Flink系列-11、Flink DataStream的Sink

版权声明&#xff1a;本文为博主原创文章&#xff0c;遵循 CC 4.0 BY-SA 版权协议&#xff0c;转载请附上原文出处链接和本声明。 大数据系列文章目录 官方网址&#xff1a;https://flink.apache.org/ 学习资料&#xff1a;https://flink-learning.org.cn/ 目录 Flink在批处…

云效/git 删除特殊字符远程分支

云效/git 删除特殊字符远程分支 一、查看所有分支二、删除分支三、验证 在使用云效时&#xff0c;不小心添加了一个错误分支 de’vdev &#xff0c;在云效手动删除时&#xff0c;报错“找不到分支”&#xff0c;无法删除。只能启动git命令进行查看&#xff0c;将步骤总结如下&a…

【JAVA】#详细介绍!!! 文件操作之文件内容操作(2)!

本文主要是针对文件内容的操作进行展开&#xff0c;文件内容操作无非就两种 1.针对文件进行“读” 2.针对文件进行“写” 目录 文件内容读写的形式 字符流 字节流 文件内容操作 InputStream&#xff1a;以字节流的形式进行读操作 创建方式&#xff1a; FileInputStream的…

2023年深圳CPDA数据分析师认证到这里就对了哦

CPDA数据分析师认证是大数据方面的认证&#xff0c;助力数据分析人员打下扎实的数据分析基础知识功底&#xff0c;为入门数据分析保驾护航。 帮助数据分析人员掌握系统化的数据分析思维和方法论&#xff0c;提升工作效率和决策能力&#xff0c;遇到问题能够举一反三&#xff0c…

MySQL索引的底层实现原理

索引的底层实现原理 数据库索引是存储在磁盘上的&#xff0c;当数据量大时&#xff0c;就不能把整个索引全部加载到内存了&#xff0c;只能逐一加载每一个磁盘块&#xff08;对应索引树的节点&#xff09;&#xff0c;索引树越低&#xff0c;越“矮胖”&#xff0c;磁盘IO次数…

主动式和被动式电容笔的区别在哪?苹果平替笔性价比高的

被动式电容笔与主动式电容笔最大的不同之处在于主动式电容笔具有更加广泛的应用领域&#xff0c;可以与各种种类的电容式屏幕相匹配。随着对电容笔的了解&#xff0c;电容笔的使用也日益广泛。而且平替电容笔的制造工艺已经日趋成熟&#xff0c;正在走向实用&#xff0c;并且已…

易观千帆 | Q1运营报告:手机银行MAU超5.3亿,行业“内卷”超出想象

易观&#xff1a;由中国电子银行网、易观分析联合发布的“2023中国手机银行综合运营报告”显示&#xff1a;在经济企稳回升的大背景下&#xff0c;中国手机银行第一季度综合运营指数季度内呈平稳上升态势&#xff0c;手机银行活跃人数环比增幅逐月递增&#xff0c;促使活跃用户…

Redis主从复制和哨兵模式

Redis主从复制 概念 主从复制&#xff0c;是指将一台Redis服务器的数据&#xff0c;复制到其他的Reds服务器。前者称为主节点(master / leader),后者称为从节点(slave / follower)。 数据的复制是单向的&#xff0c;只能由主节点到从节点。 Master以写为主&#xff0c;Slave…

无公网IP,SSH远程连接Linux CentOS服务器【内网穿透】

目录 视频教程 1. Linux CentOS安装cpolar 2. 创建TCP隧道 3. 随机地址公网远程连接 4. 固定TCP地址 5. 使用固定公网TCP地址SSH远程 本次教程我们来实现如何在外公网环境下&#xff0c;SSH远程连接家里/公司的Linux CentOS服务器&#xff0c;无需公网IP&#xff0c;也不…

Go语言的基础语法以及变量和常量

目录 基础语法 行分隔符 注释 标识符 变量 声明 赋值 作用域 常量 声明 iota 基础语法 行分隔符 在Go程序中&#xff0c;一般一行就是一个语句&#xff0c;不像Java等可以在一行写多个语句一样&#xff0c;而且最后也不需要用";"来结尾。 例如&#xf…

【华为OD机试 2023最新 】箱子之字形摆放(C语言题解 100%)

文章目录 题目描述输入描述输出描述备注用例题目解析C语言题目描述 有一批箱子(形式为字符串,设为str), 要求将这批箱子按从上到下以之字形的顺序摆放在宽度为 n 的空地,请输出箱子的摆放位置。 例如:箱子ABCDEFG,空地宽度为3,摆放结果如图: 则输出结果为: AFG BE C…

Linux Shell编程入门到实战(六)

&#x1f353; 简介&#xff1a;java系列技术分享(&#x1f449;持续更新中…&#x1f525;) &#x1f353; 初衷:一起学习、一起进步、坚持不懈 &#x1f353; 如果文章内容有误与您的想法不一致,欢迎大家在评论区指正&#x1f64f; &#x1f353; 希望这篇文章对你有所帮助,欢…

国考省考结构化面试:整体介绍,考试题型,考试流程,仪表着装,如何备考?

国考省考结构化面试&#xff1a;整体介绍&#xff0c;考试题型&#xff0c;考试流程&#xff0c;仪表着装&#xff0c;如何备考&#xff1f; 2022找工作是学历、能力和运气的超强结合体! 公务员特招重点就是专业技能&#xff0c;附带行测和申论&#xff0c;而常规国考省考最重…

基于ChatGPT的文档知识库客服系统-支持上传网址/文本/docx等数据

现在&#xff0c;很多公司都有自己的内容知识库&#xff0c;会产生大量的碎片话的内部知识&#xff0c;但是这样内部知识难以整合搜索。 我开发的文档知识库客服系统 gofly.v1kf.com &#xff0c;可以应用于企业内部知识库管理&#xff0c;用户可以使用自然语言提问&#xff0c…

杂谈:铜钱儿

我个人是比较喜欢铜钱儿的。 收藏其实谈不上&#xff0c;因为我不买什么名品&#xff0c;都是玩儿一些屌丝钱&#xff0c;穷嘛&#xff0c;这个也没啥好掩饰的~ 瞎聊点儿钱币的话题吧。 小时候是家里偶尔能发现铜钱儿&#xff0c;一般都是清朝的&#xff0c;乾隆居多。有时候地…

【苹果IM群发家庭推日历推群发】筛选“兼容性”,默认为高效,挑选“兼容性”视频和图象不操纵HEVC的新格式,承袭使用旧的MPEG格式

推荐内容IMESSGAE相关 作者✈️IMEAE推荐内容iMessage苹果推软件 *** 点击即可查看作者要求内容信息作者✈️IMEAE推荐内容1.家庭推内容 *** 点击即可查看作者要求内容信息作者✈️IMEAE推荐内容2.相册推 *** 点击即可查看作者要求内容信息作者✈️IMEAE推荐内容3.日历推 *** …

Vue学习笔记(0504)

此页面对应着创建的Vue项目的显示页面 默认可以从下面的地址进行访问&#xff1a;http://localhost:8080 这里由于创建项目时我们选择了语法规范&#xff0c;所以我们在保存时哪些不符合代码规范的地方就会报错&#xff0c;只有修正代码规范后错误才会消失。 这里可以看出我们…

PyQt5桌面应用开发(7):文本编辑+语法高亮与行号

本文目录 PyQt5桌面应用系列代码编辑和语法高亮的亿点点细节作为用户报表的文本控件作为编辑器的文本控件代码编辑器的需求 代码编辑[^1]语法高亮[^2]小结 PyQt5桌面应用系列 PyQt5桌面应用开发&#xff08;1&#xff09;&#xff1a;需求分析 PyQt5桌面应用开发&#xff08;2&…

三、Spring Cloud Alibaba组件nacos

一、什么是Nacos 官方地址&#xff1a; https://nacos.io/zh-cn/docs/v2/what-is-nacos.html 概念&#xff1a; 服务&#xff08;Service&#xff09;是 Nacos 世界的一等公民。Nacos 支持几乎所有主流类型的“服务”的发现、配置和管理。即集注册中心配置中心服务管理的一个平…

【苹果推IM,苹果iMessage相册推】当Apple APNS推送服务器从您的应用程序接吸取注册消息时,它将为您回到一串devicetoken(很是重要)

推荐内容IMESSGAE相关 作者✈️IMEAE推荐内容iMessage苹果推软件 *** 点击即可查看作者要求内容信息作者✈️IMEAE推荐内容1.家庭推内容 *** 点击即可查看作者要求内容信息作者✈️IMEAE推荐内容2.相册推 *** 点击即可查看作者要求内容信息作者✈️IMEAE推荐内容3.日历推 *** …