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定位点有两种情况。
- 未指定left,rignt,top,bottom,此时absolute元素的左上角定位点位置就是该元素正常文档流里的位置。
- 设定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(最近的块级祖先元素)定位。
而后,元素定位表现为在跨越特定阈值前为相对定位,之后为固定定位。