html – 使用伪元素创建背景叠加

前端之家收集整理的这篇文章主要介绍了html – 使用伪元素创建背景叠加前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我的目标是拥有任何背景的div,然后使用伪元素来创建透明的白色叠加层,从而“减轻”div的背景.但是,“覆盖”必须在div的内容之下.所以,在下面的例子中:
  1. <div class="container">
  2. <div class="content">
  3. <h1>Hello,World</h1>
  4. </div>
  5. </div>
  6.  
  7. .container {
  8. background-color: red;
  9. width: 500px;
  10. height: 500px;
  11. position: relative;
  12. }
  13. .content {
  14. background-color: blue;
  15. width: 250px;
  16. }
  17. .container::before {
  18. content:"";
  19. display: block;
  20. height: 100%;
  21. position: absolute;
  22. top: 0;
  23. left: 0;
  24. width: 100%;
  25. z-index: 1;
  26. background-color: rgba(255,255,.8);
  27. }

.content div不应该是“下面”的白色叠加层,也就是.container :: before.

我不喜欢在.content上使用z-index,但如果这是唯一的解决方案,我可以这样做.

最终目标:文字和蓝色不应覆盖红色.

JS小提琴:http://jsfiddle.net/1c5j9n4x/

解决方法

如果伪元素具有z-index,那么您需要定位.content元素并将z-index值添加establish a stacking context.

Updated Example

  1. .content {
  2. background-color: blue;
  3. width: 250px;
  4. position: relative;
  5. z-index: 1;
  6. }

你也可以从伪元素中删除z-index,然后只是放置.content元素.在这样做时,这些元素都不需要z-index.这个原因是因为:before伪元素本质上是一个先前的兄弟元素.因此,后续的.content元素位于顶部.

Alternative Example

  1. .content {
  2. background-color: blue;
  3. width: 250px;
  4. position: relative;
  5. }
  6. .container::before {
  7. content:"";
  8. display: block;
  9. height: 100%;
  10. position: absolute;
  11. top: 0;
  12. left: 0;
  13. width: 100%;
  14. background-color: rgba(255,.8);
  15. }

猜你在找的HTML相关文章