absolute
CSS postion属性用于指定一个元素在文档中的定位方式。top、right、bottom、left属性则决定了该元素的最终位置。
定位类型
-
定位元素是其计算后位置属性为relative、absolute、fixed或sticky的元素。
-
相对定位元素是计算后位置属性为relative的元素。
-
绝对定位元素是计算后位置属性为absolute或fixed的元素。
-
粘性定位元素是计算后位置属性为sticky的元素。
除了刚刚描述的情况(绝对定位元素填充可用空间): -
如果top和bottom都被指定(严格来说,这里指定的值不能为auto),top优先。
-
如果制定了left和right,当direction设置为ltr(水平水榭的中文、英语)时,left优先,当direction设置为rtl(阿拉伯语、希伯来语、波斯语由右向左书写)时 right 优先。
语法
position属性被指定为从下面的值列表中选择的单个关键字。
static
该关键字指定元素使用正常的布局行为,即元素在文档常规流中当前的布局位置。此时top、right、bottom、left和z-index属性无效。
relative 相对定位
该关键字下,元素先放置在未添加定位是的位置,在不改变页面布局的前提现调整元素位置(因此会在此元素未添加定位时所在的位置留下空白)。position:relative对table-*-group,table-row,table-column,table-cell,table-caption元素无效。
absolute 绝对定位
元素会被移除正常文档流,并不为元素预留空间,通过指定匀速相对于最近的非static定位祖先元素的偏移,来确定元素的位置。绝对定位的元素可以设置外边距(margins),且不会与其他边距合并。
fixed 固定定位
元素会被移除正常文档流,并不为元素预留空间,而是通过指定元素相对于屏幕视口的位置来指定元素位置。元素的位置在屏幕滚动时不会改变。打印时,元素会出现在的每页的固定位置。fixed属性会创建新的层叠上下文。当元素祖先的transform、perspective、filter或者backdrop-filter属性非none是,容器由视口改为祖先。
stick 粘性定位
元素根据正常文档进行定位,然后相对它最近的滚动祖先和最近的块级祖先,包括table-related元素,基于top、right、bottom和left的值进行偏移。偏移值不会影响任何其他元素的位置。改值总是会创建一个新的层叠上下文,注意,一个skicky元素会‘固定’在离他最近的一个拥有‘滚动机制’的祖先上(当该祖先的overflow是hidden、scroll、auto或overlay时),即便这个祖先不是最近的真实可滚动的最先.这有效的抑制了任何’sticky’行为。