position属性
position属性的值:absolute,fixed,relative,static,inherit
relative:根据它原来的静态位置定位,但是其原有的占位会保留;
absolute:脱离文档流,有定位父级就根据最近的定位父级定位;无定位父级就根据文档定位;
层级:在html中越靠后的元素,层级越高。
fixed:脱离文档流,相对于浏览器窗口定位,但是有兼容性问题,用js解决;
static:无关紧要的一玩意,忽略 = =;
inherit,继承父级的position属性值;
模拟fixed固定定位:
html{h:100%; overflow:hidden;}去掉文档滚动条,系统默认滚动条在document上
body{margin:0; h:100%;overflow:auto;}滚动条给body
.box{ h:2000;} 最外层div设置高度出现滚动条
.div{ w:100; h:100; position:absolute;left:100;top:100;}根据文档定位
定位的兼容性问题:
如果这里用的是relative,那么父级的overflow就会不起作用;因为在ie6,7下,子有相对定位,父级有overflow无效;
绝对定位:在ie6下,绝对定位元素的父级宽高是奇数的时候,元素得right和bottom值会有1px的偏差,要避免宽高是奇数
固定定位:在ie6下固定不了,可用js解决或者上面的模拟;
更新:
sticky属性
设置了sticky的元素,在屏幕范围(viewport)时该元素的位置并不受到定位影响(设置是top、left等属性无效),当该元素的位置将要移出偏移范围时,定位又会变成fixed,根据设置的left、top等属性成固定位置的效果。
可以知道sticky属性有以下几个特点:
- 该元素并不脱离文档流,仍然保留元素原本在文档流中的位置。
- 当元素在容器中被滚动超过指定的偏移值时,元素在容器内固定在指定位置。亦即如果你设置了top: 50px,那么在sticky元素到达距离相对定位的元素顶部50px的位置时固定,不再向上移动。
- 元素固定的相对偏移是相对于离它最近的具有滚动框的祖先元素,如果祖先元素都不可以滚动,那么是相对于viewport来计算元素的偏移量
比较蛋疼的是这个属性的兼容性还不是很好,目前仍是一个试验性的属性,并不是W3C推荐的标准。它之所以会出现,也是因为监听scroll事件来实现粘性布局使浏览器进入慢滚动的模式,这与浏览器想要通过硬件加速来提升滚动的体验是相悖的。
具体情况可以看下图,基本上可以说这个属性使用的浏览器只有FireFox和iOS的Safari:

简单的说,要让sticky属性生效的条件有以下两点:
- 一个是元素自身在文档流中的位置
- 另一个是该元素的父容器的边缘
第一点上面已经讲过了,如果设置了top: 50px,那么元素在达到距离顶部50px时才会发生定位,否则并不会发生定位。
第二点则需要考虑父容器的高度情况:sticky元素在到达父容器的底部时,则不会再发生定位,如果父容器高度并没有比sticky元素高,那么sticky元素一开始就达到了底部,并不会有定位的效果。
此外还有一点就是父元素的overflow属性,如果父元素的overflow属性并不是默认的visible属性,那么sticky元素则相对于该父元素定位。也就是如果要定位在顶部的话,此时这个效果就无效了。。。
转自文章:CSS中position属性介绍(新增sticky)

浙公网安备 33010602011771号