position

语法:

positionstatic | relative | absolute | fixed | center | page | sticky

默认值static

适用于:除 <' display '> 属性定义为table-column-group | table-column之外的所有元素

继承性:无

动画性:否

计算值:指定的值

取值:

static:
对象遵循常规流。 <' top '>,<' right '>,<' bottom '>,<' left '>等属性不会被应用。
relative:
对象遵循常规流,并且参照自身在常规流中的位置通过 <' top '>,<' right '>,<' bottom '>,<' left '>属性进行偏移时不影响常规流中的任何元素。
absolute:
对象脱离常规流,使用 <' top '>,<' right '>,<' bottom '>,<' left '>等属性进行绝对定位,盒子的偏移位置不影响常规流中的任何元素,其margin不与其他任何margin折叠。
fixed:
对象脱离常规流,使用 <' top '>,<' right '>,<' bottom '>,<' left '>等属性以窗口为参考点进行定位,当出现滚动条时,对象不会随着滚动。
center:
对象脱离常规流,使用 <' top '>,<' right '>,<' bottom '>,<' left '>等属性指定盒子的位置或尺寸大小。盒子在其包含容器垂直水平居中。盒子的偏移位置不影响常规流中的任何元素,其margin不与其他任何margin折叠。(CSS3)
page:
盒子的位置计算参照absolute。盒子在分页媒体或者区域块内,盒子的包含块始终是初始包含块,否则取决于每个absolute模式。(CSS3)
sticky:
对象在常态时遵循常规流。它就像是relativefixed的合体,当在屏幕中时按常规流排版,当卷动到屏幕外时则表现如fixed。该属性的表现是现实中你见到的吸附效果。(CSS3)

说明:

检索对象的定位方式。
  • 当 <' position '> 的值为非static时,其层叠级别通过 <' z-index '> 属性定义。
  • 绝对定位的元素,在 <' top '>,<' right '>,<' bottom '>,<' left '>属性未设置时,会紧随在其前面的兄弟元素之后,但在位置上不影响常规流中的任何元素。用这个特性你或许会干这样的事:demo
  • 对应的脚本特性为position

兼容性:

  • 浅绿 = 支持
  • 红色 = 不支持
  • 粉色 = 部分支持
Values IE Firefox Chrome Safari Opera iOS Safari Android Browser Android Chrome
Basic Support 6.0+ #1 2.0+ #2 4.0+ 3.1+ 4.0+ 3.2+ 2.1+ 18.0+
fixed 6.0 2.0+ 4.3 2.3
7.0+ 5.0+ 3.0+
center | page 11.0 38.0 43.0 8.1 28.0 8.1 4.4.4 40.0
sticky 11.0 31.0 43.0 6.0 28.0 5.1 4.4.4 40.0
32.0+ 6.1-8.1
-webkit-
6.0-8.1
-webkit-
  1. IE如果在 quirks mode下将不支持;
  2. Firefox30.0开始支持 tr, thead, tfoot, tbody 定义 relative,Firefox30.0之前的版本及其它浏览器都只能给 table 定义 relative 用以约束内部元素的定位;

示例: