• [转]position,z-index,float覆盖问题


    原文:https://blog.csdn.net/qq_28300493/article/details/52327449?utm_medium=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.channel_param&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.channel_param

    https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Positioning/Understanding_z_index/The_stacking_context

    形成的stack context的可能情况:

    ________________________________________________________________________

    最近仿写天猫首页时,总是遇到position覆盖问题。因此,特来总结一番。
    一般定位除了margin,padding普通流的定位外,还有position ,float等定位。
    这些都是定位,那遵循什么规则能保证各种之间不冲突呢?

    以下均在chrome等A等浏览器中测试一致

    表意

    position

    absolute(绝对定位)/relative(相对定位)/fixed(相对浏览器窗口定位)/static(静态,默认。)
    relative相对于自己在普通文档流中的位置。
    absolute相对与上级节点定位为abs/rel的元素或者浏览器左上角。
    fixed相对于浏览器窗口

    z-index

    1000;//在本节点下的覆盖优先级为1000,越大就在页面的越上方

    float

    left(左浮动)/right(右浮动)
    float的相对,知道碰到浏览器边缘或者其他浮动元素的边缘(因此可能覆盖其他未浮动元素)。脱离了普通文档流

    现象解释

    position

    absolute总是会覆盖或者被覆盖。以为,absolute是绝对定位,总是相对与父节点(定位为rel/abs)的左上角的。与其他元素无关,只与父元素有关。一层一层的关系得到的一个位置。既然已经脱离了普通的文档流,那么其他元素还可以重复使用原来的位置。即,可能会被覆盖。
    代码如下:

    <style>
        div{border: 1px solid red; 200px;height: 200px;background-color: black;}
    </style>
    <div style="position: absolute; 100px;height: 100px;</div>
    <div></div>
    <div style="position:absolute;300px;height: 300px;">
        <div style="position: absolute;100px;height: 200px;</div>
    </div>

    这里写图片描述

    ps:如上图,前面一个div绝对定位,蓝色。有一个普通流的黑色div兄弟。前者盖住了后者。因为前者脱离普通文档流不占位。
    下方的div完全不受影响。相对于黑色的普通div定位。

    总之,absolute定位不会被非上级且非普通流 的元素所影响。兄弟节点直接不影响。如果删除上例的第二个空div,则下放的div会覆盖上面蓝色的div.

    relative总是不会被覆盖。但是在平时的布局中又不能起到很大的重要。

    float

    float只与float关。不受position的影响。同样只受父节点的影响。

    <style>
        div{border: 1px solid red;}
    </style>
    <div style="position:absolute;100px;height: 400px;">
        <div style="float: left;350px;height: 50px;</div>
    </div>
    
    <div style="position:absolute;300px;height: 300px;">
        <div style="position: absolute;100px;height: 200px;</div>
    </div>
    <div style="float: left; 100px;height: 100px;此时相对于body</div>   

    这里写图片描述

    两个float没有相互影响(没有并排)。

    总结

    float只影响兄弟为float的。
    position只受祖父(祖父中最近的定位为rel/abs的元素,没有就是浏览器)影响。absolute相对于父节点左上角,若前面有定位为非rel/abs/fix元素则相对于该元素的左下角,即不挤占。同层的position,会覆盖,即相互之间不影响。relative只是相对与普通流的位置而已,不会发生覆盖。

    小疑挖掘

    那么,为什么绝对定位加负边距可以居中呢?!why?
    请点击下一篇博客>>>>>>

  • 相关阅读:
    eclipse不提示
    怎么在eclipse中安装properties插件
    表单验证之validform.js使用方法
    Activiti Service介绍
    activiti插件安装-离线安装
    三分钟明白 Activiti工作流 -- java运用
    Eclipse中快捷键Ctrl + Alt + 向上箭头 或者 Ctrl + Alt + 向下箭头与Windows冲突
    Eclipse 从git导入maven多模块项目
    封印
    教主的花园
  • 原文地址:https://www.cnblogs.com/oxspirt/p/13992110.html
Copyright © 2020-2023  润新知