前端常见面试题之display:none和visibility:hidden的区别

display:none和visibility:hidden都可以让一个div消失,那他们具体的区别在哪里呢:

  1. visibility:hidden,内容不显示,但是内容占用相关空间;display:none,内容不显示,也不占用相关内存。

(1)visibility:hidden时,相关内容不显示,但是占用空间。


相关代码:

</p><p data-track='108'>visibility:hidden和display:none的区别</p><p data-track='109' class='syl-line-pure-english'>

  • 列表 A
  • 列表 B
  • 列表 C(visibility:hidden)
  • 列表 D

(2)display:none时,相关内容不显示,也不占用空间


相关代码:

</p><p data-track='193'>visibility:hidden和display:none的区别</p><p data-track='194' class='syl-line-pure-english'>

  • 列表 A
  • 列表 B
  • 列表 C(display:none)
  • 列表 D

2.visibility:hidden有继承性,父元素hidden,它的子元素也会继承hidden的属性,但是如果子元素有主见,自己单独定义一个visibility:visible的属性,那么子元素自己就可以显示出来。而display:none的父元素定义好后,子元素定义visibility:visible或者display:block是没有效果的。

(1)父元素应用visibility:hidden时,父元素被隐藏,如果子元素应用了visibility:visible,那么子元素就会正常显示出来。

相关代码:

</p><p data-track='213'>visibility:hidden和display:none的区别</p><p data-track='214' class='syl-line-pure-english'>

  • 列表 A
  • 列表 B
  • ul被隐藏,列表 C(visibility: visible)显示出来
  • 列表 D

(2)如果父元素应用了display:none,子元素应用visibility:visible或display:block是不起作用的。


相关代码:

</p><p data-track='236'>visibility:hidden和display:none的区别</p><p data-track='237' class='syl-line-pure-english'>

  • 列表 A
  • 列表 B
  • ul被隐藏,列表 C(visibility: visible)显示不出来
  • 列表 D(display:block)

原文链接:,转发请注明来源!