css – 绝对div指的是父母的父母

简单的问题,难以找到答案.

所以我有3个div.

<div style="position: relative;" class="div-1">

        <div style="position: relative;" class="div-2">

            <div style="position: absolute;" class="div-3">

                Target Div-1's position relative.

            </div>

        </div>

    </div>

第三个div是绝对定位的,但它的目标是直接父:div-2.我希望它以div-1为目标.我怎么能实现这样的呢?

解决方法

MDN’s docs on POSITION声明:

absolute
Do not leave space for the element. Instead,position it at a specified position relative to its closest positioned ancestor or to the containing block. Absolutely positioned Boxes can have margins,they do not collapse with any other margins.

所以,答案并不难找到……在这种结构中无法做到.

唯一的方法是如果最接近的定位元素是第一个div:

<div style="position: relative;" class="div-1">
    <div class="div-2">
        <div style="position: absolute;" class="div-3">
            Target Div-1's position relative.
        </div>
    </div>
</div>

如果您无法更改HTML,可以使用css类覆盖它:

.div-2 { position: initial !important; }

相关文章

Css3如何实现鼠标移上变长特效?(图文+视频)
css3怎么实现鼠标悬停图片时缓慢变大效果?(图文+视频)
jquery如何实现点击网页回到顶部效果?(图文+视频)
css3边框阴影效果怎么做?(图文+视频)
css怎么实现圆角边框和圆形效果?(图文+视频教程)
Css3如何实现旋转移动动画特效