visibillity和display:none产生的回流和重绘

Posted coderwhytop

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了visibillity和display:none产生的回流和重绘相关的知识,希望对你有一定的参考价值。

visibility:hidden会保留元素的空间,仅为视觉上的完全透明(看不见、摸得着)
display:none不为被隐藏的对象保留其物理空间(看不见摸不着)

何为重绘(repaint)
repaint发生的时候,元素的外观会被改变,且在没有改变布局的情况下发生,如改变:
outline、visibility、backgroundcolor
不会影响到dom结构的变化,此时只发生repaint
何为渲染(reflow)
峪repaint的区别在于他会影响到dom结构的渲染,同时会触发repaint,会改变本子和所有父辈元素(祖先),这种开销很昂贵,会导致性能下降,而且页面元素越多,效果约明显。

在这里,display:none会发生reflow;而visibility:hidden只会触发repaint。

以上是关于visibillity和display:none产生的回流和重绘的主要内容,如果未能解决你的问题,请参考以下文章

前端面试题-display:none和visibility:hidden的区别

display:none和visiblity:hidden区别

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

如何在 display:none 和 display:block 之间转换?

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

display:none 和visibility:hidden的区别