值得一看
双11 12
广告
广告

CSS中position属性absolute和relative的区别

position: relative 是原地偏移且保留文档流,而 position: absolute 是脱离文档流的绝对定位。1. position: relative 元素仍占据原有空间,偏移基于自身原位置,常用于微调布局或作为 absolute 元素的定位参考;2. position: absolute 元素脱离文档流,不保留原有空间,定位基于最近的非 static 定位祖先元素,适合需要独立定位的场景;3. 使用时需注意:absolute 元素必须指定 top、left 等值,且其父容器最好设置为 relative 等定位方式以控制定位范围,同时通过 z-index 可调节堆叠层级。

CSS中position属性absolute和relative的区别

在网页布局中,position: absolute 和 position: relative 是两个常用的定位方式,它们虽然都属于定位属性,但行为和使用场景差异很大。理解它们的区别,能帮助你更精准地控制元素的位置。

position: relative 是“原地偏移”

设置 position: relative 的元素,仍然保留在文档流中原本的位置。你可以通过 top、bottom、left、right 属性让它相对于自己原来的位置进行偏移,但不会脱离文档流,也不会影响其他元素的布局。

举个例子:

立即学习“前端免费学习笔记(深入)”;

.box {
position: relative;
top: 20px;
left: 30px;
}

这个 .box 元素会从它原本的位置向下移动20px,向右移动30px,但它原来的空间依然保留,其他内容不会填补它原来的位置。

常见用途包括:

  • 微调元素位置而不影响整体布局
  • 作为 absolute 定位子元素的“参考点”

position: absolute 是“脱离文档流的绝对定位”

一旦设置了 position: absolute,元素就会完全脱离文档流,不再占据原来的空间。它的位置是相对于最近的设置了非 static 定位的祖先元素来确定的。如果没有这样的祖先,它就会一直向上找,直到视口或某个固定定位的祖先为止。

例如:

.parent {
position: relative;
}
.child {
position: absolute;
top: 10px;
left: 20px;
}

在这个例子中,.child 会以 .parent 为参考点,出现在距离父元素上边10px、左边20px的位置。

需要注意的几点:

  • 脱离文档流后,不影响其他元素布局
  • 必须明确指定 top、left 等值才能生效
  • 如果没有定位过的祖先元素,可能会跑到页面意想不到的位置

使用时的一些小技巧

  • 想让一个 absolute 元素在某个容器内定位?那这个容器必须设置成 relative、absolute、fixed 或 sticky。
  • 多层嵌套定位时,注意层级关系,可以通过 z-index 控制堆叠顺序。
  • relative 更适合微调,absolute 更适合独立定位。

基本上就这些。这两个属性看起来简单,但在实际开发中很容易因为理解不到位而出错,尤其是在复杂布局中。

温馨提示: 本文最后更新于2025-06-13 10:40:45,某些文章具有时效性,若有错误或已失效,请在下方留言或联系易赚网
文章版权声明 1 本网站名称: 创客网
2 本站永久网址:https://new.ie310.com
1 本文采用非商业性使用-相同方式共享 4.0 国际许可协议[CC BY-NC-SA]进行授权
2 本站所有内容仅供参考,分享出来是为了可以给大家提供新的思路。
3 互联网转载资源会有一些其他联系方式,请大家不要盲目相信,被骗本站概不负责!
4 本网站只做项目揭秘,无法一对一教学指导,每篇文章内都含项目全套的教程讲解,请仔细阅读。
5 本站分享的所有平台仅供展示,本站不对平台真实性负责,站长建议大家自己根据项目关键词自己选择平台。
6 因为文章发布时间和您阅读文章时间存在时间差,所以有些项目红利期可能已经过了,能不能赚钱需要自己判断。
7 本网站仅做资源分享,不做任何收益保障,创业公司上收费几百上千的项目我免费分享出来的,希望大家可以认真学习。
8 本站所有资料均来自互联网公开分享,并不代表本站立场,如不慎侵犯到您的版权利益,请联系79283999@qq.com删除。

本站资料仅供学习交流使用请勿商业运营,严禁从事违法,侵权等任何非法活动,否则后果自负!
THE END
喜欢就支持一下吧
点赞11赞赏 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容