首页前端开发CSS深入解析CSS中的绝对定位,彻底理解它!

深入解析CSS中的绝对定位,彻底理解它!

时间2024-01-28 12:04:03发布访客分类CSS浏览579
导读:收集整理的这篇文章主要介绍了深入解析CSS中的绝对定位,彻底理解它!,觉得挺不错的,现在分享给大家,也给大家做个参考。本篇文章给大家解析一下CSS中的绝对定位,带大家彻底理解它,希望对大家有所帮助!与其说定位一个元素是定位元素自身的位置,不...
收集整理的这篇文章主要介绍了深入解析CSS中的绝对定位,彻底理解它!,觉得挺不错的,现在分享给大家,也给大家做个参考。本篇文章给大家解析一下CSS中的绝对定位,带大家彻底理解它,希望对大家有所帮助!

与其说定位一个元素是定位元素自身的位置,不如说是元素的容器位置。为了能够定位自己,它必须知道自己将相对于哪个父div 来定位。【相关推荐:《css视频教程》】

下面的代码展示了4个嵌套的 div , .box-1.box-3 仅仅通过 display: flexmargin: auto 来实现居中。 .box-4 没有设置 margin ,处于文档流中默认的位置。

body>
      div class="box-1">
        div class="box-2">
          div class="box-3">
            div class="box-4">
    /div>
          /div>
        /div>
      /div>
    /body>
    

所有元素都没有设置 posITion 属性

body {
      display: flex;
}
.box-1,.box-2,.box-3 {
      display: flex;
      margin: auto;
}
    

.box-4 在默认位置

元素要想定位自己,必须知道2件事:

  • 通过 top, right, bottom, left 设置的值
  • 相对于哪个父级元素来定位

当我们给 .box-4 添加 position: absolute 属性后,发现它从普通文档流中脱离出来了。在没有设置位置属性的情况下,它只是呆在默认位置,也就是父容器的左上角。

.box-4 绝对定位时位置无偏移

通过添加 top: 0left: 0 ,元素必须要知道哪个元素将作为定位的参考容器。 可以看到这里元素被定位到了屏幕左上角。 .box-4 会先检查它的父容器是否设置了 position 属性。一开始,它发现 .box-3 没有设置定位属性,然后它就继续往上一层 .box-2.box-1 , 发现它们都没有设置可用的 position 属性 。

最终 .box-4 也没能找到可以用于定位参考的父级元素,最后只能以 body 作为定位参考。 元素最终被定位在屏幕左上角:

.box-4 绝对定位,所有父元素都未设置 position 属性

当我们给 .box-1 设置 position: relative 后 , .box-4 发现有了可用的定位参考。并最终相对于 .box-1 实现了定位:

.box-4 绝对定位,.box-1 相对定位,.box-2.box-3 不变

绝对定位元素将相对于离它最近的祖先元素来定位自己。

一旦找到了可用的祖先元素, 其它元素将不再与它相关(比如 box2 和 box3)。 下面的图片展示了分别给 .box-2.box-3 设置 position:relative 之后的效果:

.box-4 绝对定位,.box-2.box-3 相对定位

原文地址:https://juejin.cn/post/7008462323316686862

作者:M酷

更多编程相关知识,请访问:编程入门!!

以上就是深入解析CSS中的绝对定位,彻底理解它!的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

CSS

若转载请注明出处: 深入解析CSS中的绝对定位,彻底理解它!
本文地址: https://pptw.com/jishu/589616.html
详解CSS中的伪元素::before和::after css常见问题:如何画多边形(三角形~六边形)

游客 回复需填写必要信息