这一次直接进入主题。css
css中最经常使用的布局类属性,一个是float,另外一个就是定位属性position。html
对于position来说,有如下属性值:浏览器
static : 无特殊定位,对象处于正常文档流。其中,left/right/top/bottom/z-index均没法生效。
relative : 对象遵循正常文档流。但将依据left/right/top/bottom等属性在正常文档流中偏移位置。可经过设置z-index控制层叠优先级。
absolute : 对象脱离正常文档流。配合使用left/right/top/bottom等属性进行绝对定位。一样,能够经过z-index控制其层叠优先级。
fixed : 对象脱离正常文档流。配合使用top,right,bottom,left等属性以当前浏览器窗口进行定位。当出现滚动条时,对象不会随着滚动。其层叠属性经过z-index控制。ide
所谓文档流,是指浏览器在渲染页面时,从上至下,从左至右的渲染和排列元素。有三种手段可使指定的元素脱离文档流,即浮动、绝对定位和相对定位。布局
下面咱们来分别探讨position指定的定位方式。post
1,静态定位(static)
static是html元素默认的定位方式,它遵循正常的文档流渲染。为元素指定left/right/top/bottom及z-index均无效。测试
2,相对定位(relative)
顾名思义,relative及相对定位。这里的重点是相对,相对于什么地方而言呢?咱们来作一个测试。spa
(1),原始未定位3d
<head> <style type="text/css"> #divA{ width:300px; height:100px; border:1px solid blue; } #divB{ width:300px; height:100px; border:1px solid red; } </style> </head> <body> <div id="divA"> contentA </div> <div id="divB"> contentB </div> </body>
页面显示为:code
(2),咱们修改divA元素的position属性。
<head> <style type="text/css"> #divA{ width:300px; height:100px; border:1px solid blue; position:relative; top:20px; left:20px; } #divB{ width:300px; height:100px; border:1px solid red; } </style> </head> <body> <div id="divA"> contentA </div> <div id="divB"> contentB </div> </body>
页面显示为:
我本身又另外画了一副图:
如今应该可以明白,相对定位相对的是它本来在文档流中的位置而进行的偏移,而咱们也知道relative定位也是遵循正常的文档流,同时它的left/right/top/bottom属性是生效的,能够说它是static到absoult的一个中间过渡属性,最重要的是它还占有文档空间,并且占据的文档空间不会随top,left,right,bottom等属性的偏移而发生变更,也就是说它后面的元素是依据上面绿色框所示的位置进行的定位,这点必定要理解。
ok,咱们知道了left/right/top/bottom属性是不会对relative定位的元素所占据的文档空间产生偏移,那么margin,padding会让该文档空间产生偏移吗?咱们依然来作一个实验。
<head> <style type="text/css"> #divA{ width:300px; height:100px; border:1px solid blue; position:relative; top:20px; left:20px; margin-bottom:20px; } #divB{ width:300px; height:100px; border:1px solid red; } </style> </head> <body> <div id="divA"> contentA </div> <div id="divB"> contentB </div> </body>
结果为:
咱们为divA设置了margin-bottom:20px; 由上面的渲染结果示意图可知。margin一样会让relative定位的元素所占据的文档空间产生偏移。同理,padding也会对relative定位的元素据点的文档空间产生影响。
3,绝对定位(absoulte)
所谓absoulte定位,也称为绝对定位。虽然它的名字叫"绝对",但我认为它的功能却更接近于"相对"。由于使用absoult定位的元素脱离文档流后,就只能根据祖先类元素(父类以上)进行定位,而这个祖先类还必须是以postion非static方式定位的。举个例子,一个div元素使用absoulte定位,它会从父类开始找起,寻找以position非static方式定位的祖先类元素,直到<html>标签为止.这里还须要注意的是,relative和static方式在最外层时是以<body>标签为定位原点的,而absoulte方式在无父级是position非static定位时是以<html>做为原点定位。在我使用的Chrome浏览器中,<html>和<body>元素相差9px左右。
<head> <style type="text/css"> #divA{ width:300px; height:100px; border:1px solid ; position:absolute; left:20px; top:20px; } #divB{ width:300px; height:100px; border:1px solid red; } </style> </head> <body> <div id="divA"> contentA </div> <div id="divB"> contentB </div> </body>
渲染结果为:
能够看到,应用了position:absolute的元素,已脱离了正常的文档流,其本来在文档中的位置会由其后继元素进行填充。
看了上面的代码后,可能有朋友会问,为何absoulte定位要加 top:0; left:0; 属性,这不是画蛇添足呢?
其实加上这两个属性是彻底必要的,由于咱们若是使用absoulte或fixed定位的话,必须指定left/right/top/bottom属性中的至少一个,不然left/right/top/bottom属性会使用它们的默认值 auto ,这将致使对象听从正常的HTML布局规则,简单讲就是都变成relative,会占用文档空间.这点很是重要,不少人使用absolute定位后发现没有脱离文档流就是这个缘由。
少了left/right/top/bottom属性不行,那若是咱们多设了呢?例如,咱们同时设置了top和bottom的属性值,那元素又该往哪偏移好呢?记住下面的规则:
若是top和bottom同时存在的话,那么只有top生效。
若是left和right同时存在的话,那么只有left生效。
既然absoulte是根据祖先类中的position非static元素进行定位的,那么祖先类中的margin/padding会不会对position产生影响呢?
<head> <style type="text/css"> #divA{ width:300px; height:100px; border:1px solid blue; position:relative; margin:20px; padding:20px; } #divB{ width:300px; height:100px; border:1px solid red; position: absolute; top:20px; left:20px; } </style> </head> <body> <div id="divA"> contentA <div id="divB"> contentB </div> </div> </body>
页面显示为:
显而易见,祖先类的margin会让子类的absoulte跟着偏移,而padding却不会让子类的absoulte发生偏移。总结一下,就是absoulte是根据祖先类的border进行的定位。
4,固定定位(fixed)
fixed定位,又称为固定定位,它和absoult定位同样,都脱离了文档流,而且可以根据left/right/top/bottom属性进行定位,但不一样的是fixed是根据窗口为原点进行偏移定位的,也就是说它不会根据滚动条的滚动而进行偏移。
5,z-index属性
z-index,又称为对象的层叠顺序,它用一个整数来定义堆叠的层次,整数值越大,则被层叠在越上面,固然这是指同级元素间的堆叠,若是两个对象的此属性具备一样的值,那么将依据它们在HTML文档中流的顺序层叠,写在后面的将会覆盖前面的。须要注意的是,父子关系是没法用z-index来设定上下关系的,必定是子级在上父级在下。
须要注意的是,使用static定位或无position定位的元素z-index属性是无效的。