CSS中position属性详解

定义:

  • static:无特殊定位,对象遵循正常文档流。top,right,bottom,left等属性不会被应用。
  • relative:对象遵循正常文档流,但将依据top,right,bottom,left等属性在正常文档流中偏移位置。而其层叠通过z-index属性定义。
  • absolute:对象脱离正常文档流,使用top,right,bottom,left等属性进行绝对定位。而其层叠通过z-index属性定义。
  • fixed:对象脱离正常文档流,使用top,right,bottom,left等属性以窗口为参考点进行定位,当出现滚动条时,对象不会随着滚动。而其层叠通过z-index属性定义。
  • sticky:对象不会脱离正常文档流,当元素在区域内,元素不受定位的影响(top、left等设置无效);当发生滚动,元素就要移出区域时,定位又会变成fixed,根据设置的left、top的值进行定位,像是fixed效果;可以简单理解为是static和fixed的结合;

tips: 什么是文档流?

  • 将窗体自上而下分成一行行, 并在每行中按从左至右的顺序排放元素,即为文档流。
  • 只有三种情况会使得元素脱离文档流,分别是:浮动(float)、绝对定位(absoulte)和固定定位(fixed)。
属性是否脱离文档流是否占位定位原点
static
relative元素本身在文档流中的位置
absoulte最近的已定位祖先元素 或 <html>元素
fixed浏览器窗口
sticky元素本身的正常位置 或 浏览器窗口

静态定位(static)

static,无特殊定位,它是html元素默认的定位方式,即我们不设定元素的position属性时默认的position值就是static,它遵循正常的文档流对象,对象占用文档空间,该定位方式下,top、right、bottom、left、z-index等属性是无效的


相对定位(relative)

相对定位相对的是它原本在文档流中的位置而进行的偏移,而我们也知道 relative定位也是遵循正常的文档流,它没有脱离文档流 ,但是它的top/left/right/bottom属性是生效的,可以说它是static到absoult的一个中间过渡属性,最重要的是它还 占有文档空间 ,而且占据的文档空间不会随 top / right / left / bottom 等属性的偏移而发生变动,也就是说它后面的元素是依据虚线位置( top / left / right / bottom 等属性生效之前)进行的定位。


绝对定位(absoulte)

absoulte定位,也称为绝对定位,使用absoult定位的元素脱离文档流后,就只能根据祖先类元素(父类以上)进行定位,而这个祖先类还必须是以postion非static方式定位的。 如果没有已定位的祖先元素,那么absolute定位的元素会相对于<html>元素(根元素)进行定位。

举个例子,a元素使用absoulte定位,它会从父类开始找起,寻找以position非static方式定位的祖先类元素(注意,一定要是直系祖先才算哦~),直到<html>元素(根元素)为止。


固定定位(fixed)

fixed定位,又称为固定定位,它和absoult定位一样,都脱离了文档流,并且能够根据top、right、left、bottom属性进行定位,但不同的是 fixed是根据窗口为原点进行偏移定位的,也就是说它不会根据滚动条的滚动而进行偏移


粘性定位(sticky)

sticky定位,又称为粘性定位,没有脱离文档流。

可以被认为是相对定位(relative)和固定定位(fixed)的混合。元素在跨越特定阈值前为相对定位(此时设定的 top, right, bottom、left 阈值并不生效),之后为固定定位。粘性定位元素并未脱离文档流。

  • 至少规定top, left ,right, bottom中的一种, 否则stikcy定位不生效,最终效果类似于relative;
  • 假设定义了top(bottom)属性. 那么父元素height不能低于top(bottom)的值;
  • 开启粘滞定位,必须配合top值使用,在没有到达top值的时候,元素是随着滚动条滚动而滚动的,当到达top值的时候,就不会随着滚动条滚动而滚动了;

z-index属性

z-index,又称为对象的层叠顺序,它用一个整数来定义堆叠的层次,整数值越大,则被层叠在越上面,当然这是指同级元素间的堆叠,如果两个对象的此属性具有同样的值,那么将依据它们在HTML文档中流的顺序层叠,写在后面的将会覆盖前面的。需要注意的是,父子关系是无法用z-index来设定上下关系的,一定是子级在上父级在下。

使用static 定位或无position定位的元素z-index属性是无效的

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

猫老板的豆

你的鼓励将是我创作的最大动力~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值