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