一、CSS定位的属性
1、position
语法:
position:static | relative | absolute | fixed | center | page | sticky
默认值:static
适用于:除display属性定义为table-column-group | table-column
之外的所有元素。
取值:
static:对象遵循常规流。此时4个定位偏移属性不会被应用。
relative:对象遵循常规流,并且参照自身在常规流中的位置通过top,right,bottom,left这4个定位偏移属性进行偏移时不会影响常规流中的任何元素。relative相对于其正常位置进行定位。因此,”left:20” 会向元素的 LEFT 位置添加 20 像素。
absolute:对象脱离常规流,此时偏移属性参照的是离自身最近的定位祖先元素,如果没有定位的祖先元素,则一直回溯到body
元素。盒子的偏移位置不影响常规流中的任何元素,其margin不与其他任何margin折叠。
元素的位置通过 “left”, “top”, “right” 以及 “bottom” 属性进行规定。在没有使用 “left”, “top”, “right” 以及 “bottom” 属性之前,基于文档流的位置停留在在文档流之外,随着滚动并不一直停留在屏幕中。
fixed:与absolute
一致,生成绝对定位的元素,但偏移定位是相对于浏览器窗口(或手机等终端窗口)进行定位。通过"left", "top", "right"
以及"bottom"
属性进行规定。当出现滚动条时,对象不会随着滚动。
center:与absolute
一致,但偏移定位是以定位祖先元素的中心点为参考。盒子在其包含容器垂直水平居中。(CSS3)
page:与absolute
一致。元素在分页媒体或者区域块内,元素的包含块始终是初始包含块,否则取决于每个absolute
模式。(CSS3)
sticky:对象在常态时遵循常规流。它就像是relative
和fixed
的合体,当在屏幕中时按常规流排版,当卷动到屏幕外时则表现如fixed
。该属性的表现是现实中你见到的吸附效果。(CSS3)
说明:
检索对象的定位方式。
- 当
position
的值为非static
时,其层叠级别通过z-index属性定义。 - 绝对定位的元素,在top,right,bottom,left属性未设置时,会紧随在其前面的兄弟元素之后,但在位置上不影响常规流中的任何元素。用这个特性你或许会干这样的事:demo
- 对应的脚本特性为position。
absolute、 relative两种情况下,top,left,right,bottom的区别:
1、position:absolute时,top、left、right、bottom是相对最近的定位父元素(absolute,relative,fixed),top是元素上边距离父元素上边的距离,left是左左相距,right是右右相距,bottom是下下相距。
设置为绝对定位的元素框从文档流完全删除,并相对于其包含块定位,包含块可能是文档中的另一个元素或者是初始包含块。元素原先在正常文档流中所占的空间会关闭&