文章来自CSS参考手册,作者:渔人码头
1.position
语法:
position:static | relative | absolute | fixed | center | page | sticky
默认值:static
适用于:除display属性定义为table-column-group | table-column
之外的所有元素
继承性:无
动画性:否
计算值:指定值
媒体:视觉
取值:
说明:
兼容性:
Values | IE | Firefox | Chrome | Safari | Opera | iOS Safari | Android Browser | Android Chrome |
---|---|---|---|---|---|---|---|---|
Basic Support | 6.0+#1 | 2.0+#2 | 4.0+ | 6.0+ | 15.0+ | 6.0+ | 2.1+ | 18.0+ |
fixed | 6.0 | 2.0+ | 4.0+ | 6.0+ | 15.0+ | 6.0+ | 2.1-2.3#3 | 18.0+ |
7.0+ | 3.0+ | |||||||
center | page | 6.0-11.0 | 2.0-42.0 | 4.0-47.0 | 6.0-9.0 | 15.0-32.0 | 6.0-9.0 | 2.1-4.4.4 | 18.0-42.0 |
sticky | 6.0-11.0 | 2.0-31.0 | 4.0-47.0 | 6.0 | 15.0-32.0 | 6.0-9.0-webkit- | 2.1-4.4.4 | 18.0-42.0 |
32.0+ | 6.1-9.0-webkit- |
- IE如果在 quirks mode下将不支持;
- Firefox30.0开始支持
tr
,thead
,tfoot
,tbody
定义relative
,Firefox30.0之前的版本及其它浏览器都只能给table
定义relative
用以约束内部元素的定位; - 需要定义了
<meta name="viewport" content="width=device-width, user-scalable=no">
才生效
2. z-index
语法:
z-index: auto | <integer>
默认值:auto
适用于:定位元素。即定义了position为非static
的元素
继承性:无
动画性:当值为<integer>时
计算值:指定的值
媒体:视觉
取值:
说明:
z-index
用于确定元素在当前层叠上下文中的层叠级别,并确定该元素是否创建新的局部层叠上下文。- 每个元素层叠顺序由所属的层叠上下文和元素本身的层叠级别决定(每个元素仅属于一个层叠上下文)。
- 同一个层叠上下文中,层叠级别大的显示在上面,反之显示在下面。
- 同一个层叠上下文中,层叠级别相同的两个元素,依据它们在HTML文档流中的顺序,写在后面的将会覆盖前面的。
- 不同层叠上下文中,元素的显示顺序依据祖先的层叠级别来决定,与自身的层叠级别无关。
- 当
z-index
未定义或者值为auto
时,在IE6,7下会创建新的局部层叠上下文,而在高级浏览器中,按照规范不产生新的局部层叠上下文,如下例:demo:
细心的你会发现上述代码在IE6,7下的呈现与高级浏览器下不同。.test1和.test2未设置z-index,在高级浏览器下不会产生新的局部层叠上下文,也就是说它们的子元素没有被新的局部层叠上下文包裹,那么它们的子元素就处在同一个层叠上下文中,可以直接通过自身的层叠级别来决定显示顺序,所以结果是.a 覆盖了.b,因为.a的层叠级别比.b高;而在IE6,7下,.test1和.test2会产生新的局部层叠上下文,即它们的子元素被新的局部层叠上下文包裹,于是子元素显示顺序只能依赖.test1和.test2层叠级别来确定。所以结果是.b 覆盖了.a,因为.b的父元素.test2在HTML文档流中排在.test1之后,后来者居上覆盖前者。参见demo: z-index创建局部层叠上下文在IE6,7下与高级浏览器下的区别
- 对应的脚本特性为zIndex。
兼容性:
Values | IE | Firefox | Chrome | Safari | Opera | iOS Safari | Android Browser | Android Chrome |
---|---|---|---|---|---|---|---|---|
Basic Support | 6.0+ | 2.0+ | 4.0+ | 6.0+ | 15.0+ | 6.0+ | 2.1+ | 18.0+ |
负值 #1 | 6.0+ | 1.0-2.0 | 4.0+ | 6.0+ | 15.0+ | 6.0+ | 2.1+ | 18.0+ |
3.0+ |
- z-index负值是CSS2.1中定义的,在CSS2中是不被支持的;
3. top、right、bottom、left
top
语法:
top: auto | <length> | <percentage>
默认值:auto
适用于:定位元素。即定义了position为非static
的元素
继承性:无
动画性:当值为<length> | <percentage>时
计算值:当position为static
时,计算值是auto
。
为relative
时,如果top
和bottom
都是auto
,则它们的计算值是0
;如果top
和bottom
其中一个为auto
,则auto
相当于另一个的负值,即top = -bottom;如果top
和bottom
的值都不为auto
,则忽略bottom
。
否则在其它情况下,当指定值为<length>时,计算值为指定值,当指定值为<percentage>时,计算值为计算后的绝对值。除去这些情况,都为auto
媒体:视觉
取值:
说明:
- 该属性用来指定盒子参照相对物顶边界向下偏移。相对定位元素的相对物是自身,绝对定位和居中定位元素是从包含块的padding边界开始计算偏移值
- 对应的脚本特性为top。
兼容性:
Values | IE | Firefox | Chrome | Safari | Opera | iOS Safari | Android Browser | Android Chrome |
---|---|---|---|---|---|---|---|---|
Basic Support | 6.0+ | 2.0+ | 4.0+ | 6.0+ | 15.0+ | 6.0+ | 2.1+ | 18.0+ |
- 在IE6及以前的版本下,如果
top
和bottom
都定义了非auto
的值,那么 bottom 的计算值将会被设置为 -top (无论是否显式的定义了 height 或 max-height),它的指定值将被忽略,说白了,你将无法在不指定某个元素高度的情况,通过给元素指定top
和bottom
的方式来进行高度拉伸;
right
语法:
right:auto | <length> | <percentage>
默认值:auto
适用于:定位元素。即定义了 <' position '> 为「非static」的元素
继承性:无
动画性:当值为<length> | <percentage>时
计算值:当position为static
时,计算值是auto
。
为relative
时,如果right
和left
都是auto
,则它们的计算值是0
;如果right
和left
其中一个为auto
,则auto
相当于另一个的负值,即left = -right;如果right
和left
的值都不为auto
,则忽略right
。
否则在其它情况下,当指定值为<length>时,计算值为指定值,当指定值为<percentage>时,计算值为计算后的绝对值。除去这些情况,都为auto
媒体:视觉
取值:
说明:
- 该属性用来指定盒子参照相对物右边界向左偏移。相对定位元素的相对物是自身,绝对定位和居中定位元素是从包含块的padding边界开始计算偏移值
- 对应的脚本特性为right。
兼容性:
Values | IE | Firefox | Chrome | Safari | Opera | iOS Safari | Android Browser | Android Chrome |
---|---|---|---|---|---|---|---|---|
Basic Support | 6.0+ | 2.0+ | 4.0+ | 6.0+ | 15.0+ | 6.0+ | 2.1+ | 18.0+ |
bottom
语法:
bottom: auto | <length> | <percentage>
默认值:auto
适用于:定位元素。即定义了 <' position '> 为「非static」的元素
继承性:无
动画性:当值为<length> | <percentage>时
计算值:当position为static
时,计算值是auto
。
为relative
时,如果top
和bottom
都是auto
,则它们的计算值是0
;如果top
和bottom
其中一个为auto
,则auto
相当于另一个的负值,即top = -bottom;如果top
和bottom
的值都不为auto
,则忽略bottom
。
否则在其它情况下,当指定值为<length>时,计算值为指定值,当指定值为<percentage>时,计算值为计算后的绝对值。除去这些情况,都为auto
媒体:视觉
取值:
说明:
- 该属性用来指定盒子参照相对物底边界向上偏移。相对定位元素的相对物是自身,绝对定位和居中定位元素是从包含块的padding边界开始计算偏移值
- 对应的脚本特性为bottom。
兼容性:
Values | IE | Firefox | Chrome | Safari | Opera | iOS Safari | Android Browser | Android Chrome |
---|---|---|---|---|---|---|---|---|
Basic Support | 6.0+ | 2.0+ | 4.0+ | 6.0+ | 15.0+ | 6.0+ | 2.1+ | 18.0+ |
- 在IE6及以前的版本下,如果
top
和bottom
都定义了非auto
的值,那么 bottom 的计算值将会被设置为 -top (无论是否显式的定义了 height 或 max-height),它的指定值将被忽略,说白了,你将无法在不指定某个元素高度的情况,通过给元素指定top
和bottom
的方式来进行高度拉伸;
left
语法:
left: auto | <length> | <percentage>
默认值:auto
适用于:定位元素。即定义了 <' position '> 为「非static」的元素
继承性:无
动画性:当值为<length> | <percentage>时
计算值:当position为static
时,计算值是auto
。
为relative
时,如果right
和left
都是auto
,则它们的计算值是0
;如果right
和left
其中一个为auto
,则auto
相当于另一个的负值,即left = -right;如果right
和left
的值都不为auto
,则忽略right
。
否则在其它情况下,当指定值为<length>时,计算值为指定值,当指定值为<percentage>时,计算值为计算后的绝对值。除去这些情况,都为auto
媒体:视觉
取值:
说明:
- 该属性用来指定盒子参照相对物左边界向右偏移。相对定位元素的相对物是自身,绝对定位和居中定位元素是从包含块的padding边界开始计算偏移值
- 对应的脚本特性为left。
兼容性:
Values | IE | Firefox | Chrome | Safari | Opera | iOS Safari | Android Browser | Android Chrome |
---|---|---|---|---|---|---|---|---|
Basic Support | 6.0+ | 2.0+ | 4.0+ | 6.0+ | 15.0+ | 6.0+ | 2.1+ | 18.0+ |
4. clip(CSS3新增属性)
语法:
clip:auto | <shape>
<shape>:rect(<number>|auto <number>|auto <number>|auto <number>|auto)
默认值:auto
适用于:绝对定位元素
继承性:无
动画性:当值为<shape>时
计算值:指定的值
媒体:视觉
取值:
说明:
兼容性:
Values | IE | Firefox | Chrome | Safari | Opera | iOS Safari | Android Browser | Android Chrome |
---|---|---|---|---|---|---|---|---|
Basic Support #1 | 6.0+ | 2.0+ | 4.0+ | 6.0+ | 15.0+ | 6.0+ | 2.1+ | 18.0+ |
rect(逗号分隔) | 6.0-7.0 | 2.0+ | 4.0+ | 6.0+ | 15.0+ | 6.0+ | 2.1+ | 18.0+ |
8.0+ |
- Basic Support包含值:auto | rect(空格分隔)