display:none和visibility: hidden区别

简介: display:none和visibility: hidden区别

空间占用方面:

  • display:none;会让元素完全从渲染树中消失,渲染的时候不占据任何空间;
  • visibility: hidden;不会让元素从渲染树消失,渲染师元素继续占据空间,只是内容不可见

继承性:

  • display: none;是非继承属性,子孙节点消失由于元素从渲染树消失造成,通过修改子孙节点属性无法显示;
  • visibility: hidden;是继承属性,子孙节点消失由于继承了hidden,通过设置visibility: visible;可以让子孙节点显式

是否会引起回流重绘:

  • 修改常规流中元素的display通常会造成文档重排。
  • 修改visibility属性只会造成本元素的重绘。

读屏器:

  • 读屏器不会读取display: none;元素内容;会读取visibility: hidden;元素内容


相关文章
|
1月前
|
前端开发 JavaScript
分析比较 opacity: 0、visibility: hidden、display: none 优劣和适用场景
在CSS中,`opacity: 0`、`visibility: hidden` 和 `display: none` 都能隐藏元素,但各有千秋。`opacity: 0` 使元素透明但仍占布局空间;`visibility: hidden` 同样保留空间但使元素完全不可见;而 `display: none` 则彻底移除元素及其所占空间。根据具体需求选择合适方式可优化页面表现与性能。
|
容器
【已解决】text-overflow: ellipsis; 不生效(除了white-space:nowrap;overflow: hidden;之外)
text-overflow: ellipsis; 不生效(除了white-space:nowrap;overflow: hidden;之外)
1128 0
|
Web App开发 前端开发 JavaScript
如何不使用 overflow: hidden 实现 overflow: hidden
如何不使用 overflow: hidden 实现 overflow: hidden
163 0
如何不使用 overflow: hidden 实现 overflow: hidden
|
前端开发 容器
CSS - float & overflow: hidden
CSS - float & overflow: hidden
178 0
|
网络协议
|
网络协议