72、隐藏元素的方法以及区别

本文详细探讨了CSS中隐藏元素的几种方式,包括display:none、visibility:hidden、opacity:0等,比较了它们在渲染树、继承属性、布局和交互上的区别,以及对屏幕阅读器的影响。
摘要由CSDN通过智能技术生成

1、隐藏元素的方法

  1. display: none:渲染树不会包含该渲染对象,因此该元素不会在页面中占据位置,也不会响应绑定的监听事件。
  2. visibility: hidden:元素在页面中仍占据空间,但是不会响应绑定的监听事件。
  3. opacity: 0:将元素的透明度设置为 0,来实现元素的隐藏。元素在页面中仍然占据空间,并且能够响应元素绑定的监听事件
  4. position: absolute:通过使用绝对定位将元素移除可视区域内,以此来实现元素的隐藏,不会影响布局,能够响应元素绑定的监听事件
  5. z-index: 负值:使其他元素遮盖住该元素,以此来实现隐藏
  6. transform: scale(0,0):将元素缩放为 0,来实现元素的隐藏。这种方法下,元素仍在页面中占据位置,但是不会响应绑定的监听事件
  7. clip/clip-path :使用元素裁剪的方法来实现元素的隐藏,这种方法下,元素仍在页面中占据位置,但是不会响应绑定的监听事件。

2、总结

  • visibility:影响布局(占据空间),影响交互(不会响应绑定事件);
  • opacity:影响布局(占据空间),不影响交互(会响应绑定事件);
  • display:不影响布局(不占据空间),影响交互;
  • position:不影响布局,不影响交互;   

3、display:none与visibility:hidden的区别:

1)在渲染树中

display:none 会让元素完全从渲染树中消失,渲染时不会占据任何空间;
visibility:hidden 不会让元素从渲染树中消失,渲染的元素还会占据相应的空间,只是内容不可见。

2)是否是继承属性

display:none 是非继承属性子孙节点会随着父节点从渲染树消失,通过修改子孙节点的属性也无法显示;
visibility:hidden 是继承属性子孙节点消失是由于继承了hidden,通过设置visibility:visible可以让子孙节点显示;

3)修改常规文档流中元素的 display 通常会造成文档的重排(不占据空间),但是修改visibility属性只会造成本元素的重绘(占据空间);

4)如果使用读屏器,设置为display:none的内容不会被读取,设置为visibility:hidden的内容会被读取。
 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值