display:none 和visibility:hidden的区别

Posted vipuser

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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;元素内容

以上是关于display:none 和visibility:hidden的区别的主要内容,如果未能解决你的问题,请参考以下文章

display:none;visibility:hidden;和opacity:0;的区别

display:none和visibility:hidden的功能是啥?

display:none 和visibility:hidden的区别

visibility:hidden和display:none的区别

visibility:hidden和display:none的区别

display:none与visible:hidden的区别