【CSS】opacity 影响 z-index 不生效

准备知识

一般来说,z-index 不生效的原因有:

  1. 父元素的 position 属性:

    z-index 只对 position 属性为 relative、absolute 或 fixed 的元素有效。

  2. 其他元素的 z-index:

    如果页面中有其他元素也设置了较高的 z-index,可能会覆盖你的 .app 元素。

  3. CSS 特性:

    z-index 的效果可能受到 CSS 特性的影响,例如 transform、opacity 等。

    确保没有其他 CSS 特性干扰 z-index 的效果。

我的项目中就是由于第三点,opacity 影响了 z-index ,导致 z-index 不生效。

我的某个元素同时具有 link 和 download 选择器,代码如下:

css 复制代码
.link {
  display: inline-block;
  margin-right: 10px;
  color: $bgGrayColor;
  font-size: $fontSize12;
  line-height: 14px;
  padding: 0 14px;
  // 字体变暗
  opacity: 0.8;  // 该 属性 导致 z-index 不生效
  // 去掉默认样式
  text-decoration: none;
}

.download {
  //局部的相对定位使用 子绝父相
  position: relative;

  .app {
    display: none;
    position: absolute;
    top: 25px;
    left: 0;
    padding: 8px;
    box-shadow: 0 4px 8px 0 rgb(0 0 0 / 10%);
    z-index: 10000;  // 不生效

    .ecode {
      width: 140px;
      height: 140px;
    }

    .name {
      color: #000;
      margin-top: 2px;
    }
  }
}

解决方法

  • 将 opacity 应用到子元素:将 opacity 应用到 .app 的子元素而不是 .app 本身,这样不会影响 .app 的堆叠上下文。
  • 或者 去除 opacity

原因分析

  • 当一个元素的 opacity 小于 1 时,它会创建一个新的堆叠上下文(stacking context),这可能会导致 z-index 无法按预期工作。
相关推荐
kyriewen12 分钟前
老板逼我上AI,我偷偷在浏览器里跑LLaMA,省下20万API费
前端·react.js·llm
Beginner x_u21 分钟前
前端八股整理(手写 02)|数组转树、数组扁平化、随机打乱一个数组
前端·数组·数组转树·数组扁平化
KaMeidebaby25 分钟前
卡梅德生物技术快报|禽类成纤维细胞 FISH 实验:鸟类性别染色体基因定位技术实现与数据验证
前端·数据库·其他·百度·新浪微博
天若有情67338 分钟前
前端高阶性能优化:跳出传统懒加载与预加载,基于用户行为做轻量预判加载
前端·性能优化
小小小小宇41 分钟前
前端转后端:SQL 是什么
前端
张元清2 小时前
React Observer Hooks:7 种监听 DOM 而不写样板代码的方式
前端·javascript·面试
广州华水科技2 小时前
单北斗GNSS变形监测是什么?主要有怎样的应用与优势?
前端
卷帘依旧2 小时前
【未完待续】React高频面试题
前端
m0_738120722 小时前
ctfshow靶场SSRF部分——基础绕过到协议攻击解题思路与技巧(一)
服务器·前端·网络·安全·php
counterxing2 小时前
AI Agent 做长任务,问题到底 出在哪?
前端·后端·ai编程