position:relative和absolute的区别、应用

position 有三个值,static(静态)、relative(相对)、absolute(绝对);由于static是所有页面元素的默认值,因此设置元素的定位类型时几乎不用这个值,除非用于覆盖之前的定义。
对于后两者,一般应用:在一个相对定位的元素里面放置一个绝对定位的元素,如图:
[img]http://blog.donews.com/images/blog_donews_com/kurt198211/129754/o_t200611523277.gif[/img]


子元素B可以通过top、right、bottom、left来精确定位,定位的参考目标就是其具有相对定位属性的父级元素A;并且设置这些偏移后,产生的空隙会被后面的元素填充(如果后面的元素足够尺寸的话)。由于B元素具有absolute定位属性,相当于从文档流中抽取出来,浮动在原平面排版上,形成“层”,如果有多个“层”,层与层之间就必然会有谁覆盖谁,谁在上谁在下的竞争关系,因此,为解决这个竞争,就产生了 z-index(空间坐标系的Z轴) 属性,谁的值大,谁就在上面。另外,如果父级元素A没有设置relative,那么B元素就会以body标签当作参考点。

对于具有position:relative属性的元素A,其top、right、bottom、left四个方向的位置偏移就会以该元素的原来位置作为参考点,而不是像上面说的,以具有relative定位属性的父级元素或body作为参考点。在设置了偏移后产生了空隙,其周围的元素并不会填充这些空隙,即使它们足够尺寸(演示)。值得注意的是,此时元素A的margin,margin将作用于该元素的原来位置,由于原位置产生偏移,该元素的最终位置将是margin与top、right、bottom、left共同作用后的位置,并且其周围元素的位置也将产生影响。

回过头来再看看 relative 里面的 absolute,比如上面的A、B两个元素,如果两个元素都设置了top、right、bottom、left,对于元素B来说,其位置偏移的参考点是元素A偏移后的位置,不是元素A的原位置,同样,如果元素B有margin,其参考点也是元素A偏移后的位置,这点很重要,这才是absolute的概念
### CSS 中 `position: relative` `position: absolute` 的区别 #### 定义与行为差异 `position: relative` 表示元素相对于其正常位置进行偏移,而该元素仍然占据文档流中的原始空间[^1]。这意味着即使设置了 `top`, `right`, `bottom`, 或 `left` 属性,页面上其他元素的位置也不会受到影响。 相比之下,`position: absolute` 将元素完全从标准文档流中移除,并将其放置在一个由最近的具有定位属性(non-static positioning context)祖先定义的新坐标系中[^2]。如果不存在这样的祖先,则绝对定位会基于初始包含块(通常是视口)。因此,使用 `absolute` 定位的盒子不再干扰周围兄弟节点的空间分配。 #### 使用场景对比 对于需要微调某个特定区域内的子组件而不改变整体结构的情况,可以考虑采用相对定位方式;而对于弹窗、工具提示或者浮动菜单之类的独立控件设计来说,绝对定位更加合适因为它们通常不需要遵循常规布局逻辑而是要精确控制显示地点[^3]。 #### 布局效果举例说明 以下是两个简单的例子分别展示了如何应用这两种不同的定位策略: ```html <div style="border: 1px solid black; width: 200px; height: 100px;"> <p style="position: relative; top: 20px;">Relative Text</p> </div> <!-- Absolute Position Example --> <div style="position: relative; border: 1px dashed red; width: 200px; height: 100px;"> <span style="position: absolute; bottom: 0; right: 0;">Absolute Span</span> </div> ``` 上述HTML片段中第一个 `<p>` 元素通过设置为 `relative` 并调整了垂直方向上的距离 (`top`) 来实现轻微移动但仍保持原有占位不变的效果[^4]; 而第二个案例里的 `<span>` 则利用了父容器设定成 `relative` 后作为参照物来进行精准摆放于右下角处[^5]. ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值