display:none和visibility: hidden区别

空间占用方面:

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

 继承性:

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

 是否会引起回流重绘:

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

 读屏器:

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

猜你喜欢

转载自blog.csdn.net/Clover_zlx/article/details/130692366
今日推荐