在css中用position 属性指定元素的定位类型。
position 属性有五个值:
- static 静态定位
- relative 相对定位
- fixed 固定定位
- absolute 绝对定位
- sticky 粘性定位
属性 | 说明 |
---|---|
position | 指定元素的定位类型。 |
right | 定义了定位元素右外边距边界与其包含块右边界之间的偏移。 |
top | 定义了一个定位元素的上外边距边界与其包含块上边界之间的偏移。 |
bottom | 定义了定位元素下外边距边界与其包含块下边界之间的偏移。 |
left | 定义了定位元素左外边距边界与其包含块左边界之间的偏移。 |
元素具备了定位属性之后,可以使用的顶部top,底部bottom,左侧left和右侧right属性定位。
正数值表示拉开距离,负数值表示距离更近。
水平方向与垂直方向,最多只能各写其中的一个方向。(static除外)。他们也有不同的工作方式,这取决于定位方法。
1)静态定位 static
默认的,相当于没有定位,top bottom left right 没有用
2)固定定位 fixed
相对于浏览器窗口的定位,即使窗口是滚动的不会影响他的位置
文档流:元素在文档中实际占据的位置,
固定定位使元素位置与文档流无关,因此不在页面中占据空间
3)相对定位 relative
相对定位元素的定位是相对其自身本来的位置
移动相对定位元素,但它原本所占的空间不会改变。
相对定位元素经常被用来作为绝对定位元素的容器块。
4)绝对定位 absolute
绝对定位的元素的位置相对于最近的已定位父元素,如果元素没有已定位的父元素,那么它的位置相对于<html>
absolute 定位使元素的位置与文档流无关,因此不占据空间。absolute 定位的元素和其他元素重叠
5)粘性定位 sticky
基于用户的滚动位置来定位
粘性定位的元素是依赖于用户的滚动,在 position:relative 与 position:fixed 定位之间切换。
它的行为就像 position:relative; 而当页面滚动超出目标区域时,它的表现就像 position:fixed;,它会固定在目标位置。
元素定位表现为在跨越特定阈值前为相对定位,之后为固定定位。
这个特定阈值指的是 top, right, bottom 或 left 之一,换言之,指定 top, right, bottom 或 left 四个阈值其中之一,才可使粘性定位生效。否则其行为与相对定位相同。该值含义是当元素距离改设定值时变成固定定位