display: none;与visibility: hidden;的区别

更新日期: 2018-03-08阅读: 2.2k标签: display

联系:它们都能让元素不可见。


区别:

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

简单理解为:none表示完全没有, 当前的位置会被后面的元素补上来,hidden仅仅是隐藏, 但是他的位置会保留。


例子:

<html>
<head>
<title>display:none和visible:hidden的区别</title>
</head>
<body >
<spanline-height: 19.5px; color: rgb(51, 153, 102);">display:none; background-color:Blue">隐藏区域</span><span>显示区域</span><br />
<spanline-height: 19.5px; color: rgb(51, 153, 102);">visibility:hidden; background-color:Blue">隐藏区域</span><span>显示区域</span>
</body>
</html>


链接: https://www.fly63.com/article/detial/485

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!