css中有哪些方式可以隐藏页面元素及区别

  

在 CSS 中,有一些不同的方式可以隐藏页面元素。下面将会细致地介绍这些方法以及它们的不同之处。

1. display: none

display: none 属性可以完全移除一个元素,该元素将不再占据与其关联的空间。在网页中,它是最常用的隐藏元素的方法之一。要注意的是它的区别,它与 visibility: hidden 的区别是,visibility: hidden 会保留元素的空间占用,而 display: none 则不会。

示例代码:

.hide {
  display: none;
}
<p class="hide">我被隐藏了</p>

2. visibility: hidden

visibility: hidden 属性比 display: none 略微来说更灵活,因为它只是隐藏了元素本身,而不是完全移除它们。这意味着它仍占据页面布局中的空间。另外需要注意的是,即使元素隐藏了,它的样式,属性和事件仍然有效。

示例代码:

.hide {
  visibility: hidden;
}
<p class="hide">我被隐藏了</p>

3. opacity: 0

opacity 属性可以达到渐隐渐现的效果,例如当页面加载时,可以将元素的 opacity 属性设为 0,然后通过 JS 或 CSS 动态地将其变更为 1 以显示元素。与前面两种方法相比,opacity 不会带来影响元素在页面布局中的行为。但它也可能导致元素本身的一些不可预测的问题,例如,元素内部的文本和图像仍存在并可能被用户选择和复制。

示例代码:

.hide {
  opacity: 0;
}
<p class="hide">我被隐藏了</p>

4. position: absolute; left: -9999px;

position 属性的 absolute 值可以将元素完全移动到浏览器窗口之外,而 left: -9999px 的值将在水平方向上隐藏它们。这是另一种比 display: nonevisibility: hidden 更深层次的方式,因为它将元素移动到完全不可见的部分。这种方法最初被用在早期搜索引擎优化技术中,以保护页面不受滥用关键字的惩罚。

示例代码:

.hide {
  position: absolute;
  left: -9999px;
}
<p class="hide">我被隐藏了</p>

总结:
不同的隐藏元素方法适合不同的情况。如果您想将元素完全移除,请使用 display: none。如果你想在保留空间的同时想把元素隐藏,你可以使用 visibility: hidden。而如果你希望使用某种动画效果来显示或者隐藏元素,你可以使用 opacity: 0。而如果希望完全将元素从页面中取走但仍然存在,在搜索引擎优化中应用时,可以使用 position: absolute; left: -9999px

相关文章