display: none; 与 visibility: hidden; 的区别
- display: none;让元素完全从渲染树中消失,渲染时不占据任何空间;visibility: hidden;不会让元素从渲染树消失,继续占据空间,只是内容不可见。
- 读屏器不会读取display: none;元素内容;会读visibility: hidden元素内容。
- 修改常规流中元素的display通常会造成文档重排。修改 visibility 属性只会造成本元素的重绘。
- display: none;是非继承属性,子孙节点消失由于元素从渲染树消失造成,通过修改子孙节点属性无法显示;visibility: hidden;是继承属性,子孙节点消失由于继承了 hidden,通过设置 visibility: visible;可以让子孙节点显式。