css position属性定位详解

postion 属性定义了一个元素在页面布局中的位置以及对周围元素的影响。该属性共有5个值:

  • position: absolute
  • position: relative
  • position: fixed
  • position: static
  • position: inherit

static

static 为 position 属性的默认值,static 元素会遵循正常的文档流,且会忽略 top,bottom,left,right 等属性。

inherit

inherit 值如同其他 css 属性的 inherit 值,即继承父元素的 position 值。

absolute

absolute是对象脱离正常文档流,使用top,right,bottom,left等属性进行绝对定位。而其层叠通过z-index属性定义。
简单的来讲就是,元素属性被设定为position:absoute后,此元素会脱离原来的文档流,相当于生成一个新的图层覆盖在原来的文档流上。原来的文档流中不存在此元素,如果他的父元素没有其他的内容,父元素会产生塌陷。
元素会随滚轴移动。
absolute定位点有两种情况。

  1. 未指定left,rignt,top,bottom,此时absolute元素的左上角定位点位置就是该元素正常文档流里的位置。
  2. 设定left,rignt,top,bottom,会根据父类开始找起 ,寻找以position非static方式定位的祖先类元素 ,直到标签为止。

3. relative

生成相对定位的元素,通过top,bottom,left,right的设置相对于其正常(原先本身)位置进行定位。可通过z-index进行层次分级。
relative元素不会脱离原来的文档流,位置移动后,原先存在于正常位置的地方会占位。移动的位置相对于原来存在的位置而言。

fixed

fixed:对象脱离正常文档流,使用top,right,bottom,left等属性以窗口为参考点进行定位,当出现滚动条时,对象不会随着滚动。而其层叠通过z-index属性定义。
fixed以窗口的视点为基准移动的,不会随滚轴移动,例如导航栏,回到开始功能。也会使父元素产生塌陷。
注意:当元素祖先的 transform 属性非 none 时,定位容器由视口改为该祖先。

sticky

sticky 英文字面意思是粘,粘贴,所以粘性定位。

这结合了 position:relative 和 position:fixed 两种定位功能于一体的特殊定位,适用于一些特殊场景。
元素先按照普通文档流定位,然后相对于该元素在流中的 flow root(BFC)和 containing block(最近的块级祖先元素)定位。
而后,元素定位表现为在跨越特定阈值前为相对定位,之后为固定定位。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值