html - z-index 不适用于元素的绝对定位

标签 html css

我正在创建一个类似于堆叠卡片的组件,我将所有卡片定位为绝对位置但面临 z-index 属性的问题,这些卡片似乎没有相对于 z-index 发生变化。

<div style="display:flex;justify-content:center;position:relative">
  <div style="height:180px;width:280px;background-color:green;position:absolute;top:70px;z-index:100;box-shadow: 0px 0px 12px 0px black"/>
    <div style="height:180px;width:260px;background-color:blue;position:absolute;top:-20px;z-index:99;left:10px;box-shadow: 0px 0px 2px 0px black"/>
      <div style="height:180px;width:240px;background-color:red;position:absolute;top:-20px;z-index:98;left:10px;box-shadow: 0px 0px 2px 0px black"/>
        <div style="height:180px;width:220px;background-color:yellow;position:absolute;top:-20px;z-index:97;left:10px;box-shadow: 0px 0px 2px 0px black"/>
</div>                                                         

最佳答案

div 闭包是错误的,但是定位也是错误的。取出左边并使顶部上升您想要重叠的像素数。

<div style="display:flex;justify-content:center;position:relative">
  <div style="height:180px;width:280px;background-color:green;position:absolute;top:70px;z-index:100;box-shadow: 0px 0px 12px 0px black"></div>
  <div style="height:180px;width:260px;background-color:blue;position:absolute;top:65px;z-index:99;box-shadow: 0px 0px 2px 0px black"></div>
  <div style="height:180px;width:240px;background-color:red;position:absolute;top:60px;z-index:98;box-shadow: 0px 0px 2px 0px black"></div>
  <div style="height:180px;width:220px;background-color:yellow;position:absolute;top:55px;z-index:97;box-shadow: 0px 0px 2px 0px black"></div>
</div>  

关于html - z-index 不适用于元素的绝对定位,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58399347/

相关文章:

html - 除了 <HR/> 在 Bootstrap 3 中画线还有其他选择吗?

jquery - 使用css从右向左滑动动画

javascript - 从外部样式化嵌套样式组件

css - Safari 中的 CSS3 渐变问题

html - CSS 规则在 IE 中有效,但在 Chrome/Firefox 中无效

javascript - 当用户点击它时更改 div 的颜色

javascript - 如何在用户点击时更改移动搜索栏的位置

JavaScript 返回功能无法在两页深度工作

javascript - 要求文档底部的 JS 文件会带来可用性问题

html - 如何创建 'responsive' 列表 : creating multiple columns to fit available width?