position属性的相关定义:css
static:无特殊定位,对象遵循正常文档流;html
relative:对象遵循正常文档流;布局
absolute:对象脱离正常文档流post
fixed:对象脱离正常文档流测试
咱们先来看看CSS3 Api中对position属性的相关定义:spa
怎么样,是否是仍是很迷糊~~ 不要紧,下面就从几个基础概念一一给你们详述:3d
什么是文档流?code
将窗体自上而下分红一行行, 并在每行中按从左至右的顺序排放元素,即为文档流。htm
只有三种状况会使得元素脱离文档流,分别是:浮动、绝对定位和相对定位。对象
静态定位(static) :
static,无特殊定位,它是html元素默认的定位方式,即咱们不设定元素的position属性时默认的position值就是static,它遵循正常的文档流对象,对象占用文档空间,该定位方式下,top、right、bottom、left、z-index等属性是无效的。
相对定位(relative) :
relative定位,又称为相对定位,从字面上来解析,咱们就能够看出该属性的主要特性:相对。可是它相对的又是相对于什么地方而言的呢?这个是个重点,也是最让我迷糊的一个地方,如今让咱们来作个测试,我想你们都会明白的:
(1) 初始未定位
1 /******初始*********/ 2 <style type="text/css"> 3 #first { width: 200px; height: 100px; border: 1px solid red; } 4 #second{ width: 200px; height: 100px; border: 1px solid blue;} 5 </style> 6 <body> 7 <div id="first"> first</div> 8 <div id="second">second</div> 9 </body>
(2) 咱们修改first元素的position属性:
<style type="text/css"> #first{ width: 200px; height: 100px; border: 1px solid red;
position: relative; top: 20px; left: 20px;} /*add position*/ #second{width: 200px; height: 100px; border: 1px solid blue;} </style>
偏移20px后:
如今看明白了吧,相对定位相对的是它本来在文档流中的位置而进行的偏移,而咱们也知道relative定位也是遵循正常的文档流,它没有脱离文档流,可是它的top/left/right/bottom属性是生效的,能够说它是static到absoult的一个中间过渡属性,最重要的是它还占有文档空间,并且占据的文档空间不会随 top / right / left / bottom 等属性的偏移而发生变更,也就是说它后面的元素是依据虚线位置( top / left / right / bottom 等属性生效以前)进行的定位,这点必定要理解。
那好,咱们知道了top / right / left / bottom 属性是不会对relative定位的元素所占据的文档空间产生偏移,那么margin / padding会让该文档空间产生偏移吗?答案是确定的,咱们一块儿来作个试验吧:
(3) 添加margin属性:
<style type="text/css"> #first{width: 200px;height: 100px;border: 1px solid red;position: relative;top: 20px;left: 20px;margin: 20px;} /* add margin*/ #second{width: 200px;height:100px;border: 1px solid blue;} </style>
绝对定位(absoulte) :
absoulte定位,也称为绝对定位,虽然它的名字号曰“绝对”,可是它的功能却更接近于"相对"一词,为何这么讲呢?原来,使用absoult定位的元素脱离文档流后,就只能根据祖先类元素(父类以上)进行定位,而这个祖先类还必须是以postion非static方式定位的.
举个例子,a元素使用absoulte定位,它会从父类开始找起,寻找以position非static方式定位的祖先类元素(注意,必定要是直系祖先才算哦~),直到<html>标签为止,这里还须要注意的是,relative和static方式在最外层时是以<body>标签为定位原点的,而absoulte方式在无父级是position非static定位时是以<html>做为原点定位。<html>和<body>元素相差9px左右。咱们来看下效果:
(4) 添加absoulte属性:
<html> <style type="text/css"> html{border:1px dashed green;} body{border:1px dashed purple;} #first{ width: 200px;height: 100px;border: 1px solid red;position: relative;} #second{ width: 200px;height: 100px;border: 1px solid blue;position: absolute;top :0;left : 0;} </style> <body> <div id="first">relative</div> <div id="second">absoult</div> </body> </html>
其实加上这两个属性是彻底必要的,由于咱们若是使用absoulte或fixed定位的话,必须指定 left、right、 top、 bottom 属性中的至少一个,不然left/right/top/bottom属性会使用它们的默认值 auto ,这将致使对象听从正常的HTML布局规则,在前一个对象以后当即被呈递,简单讲就是都变成relative,会占用文档空间,
这点很是重要,不少人使用absolute定位后发现没有脱离文档流就是这个缘由,这里要特别注意~~~
少了left/right/top/bottom属性不行,那若是咱们多设了呢?
例如,咱们同时设置了top和bottom的属性值,那元素又该往哪偏移好呢?记住下面的规则:
既然absoulte是根据祖先类中的position非static元素进行定位的,
那么祖先类中的margin/padding会不会对position产生影响呢?
看个例子先:
(5) 在absoulte定位中添加margin / padding属性:
#first{width: 200px;height: 100px;border: 1px solid red;position: relative;margin:40px;padding:40px;} #second{width: 200px;height:100px;border: 1px solid blue;position: absolute;top:20px;left:20px;} <div id="first">first <div id="second">second</div> </div>
看懂了,祖先类的margin会让子类的absoulte跟着偏移,而padding却不会让子类的absoulte发生偏移。
总结一下,就是absoulte是根据祖先类的border进行的定位。
Note : 绝对(absolute)定位对象在可视区域以外会致使滚动条出现。
而放置相对(relative)定位对象在可视区域以外,滚动条不会出现。
固定定位(fixed):
fixed定位,又称为固定定位,它和absoult定位同样,都脱离了文档流,
而且可以根据top、right、left、bottom属性进行定位,
但不一样的是fixed是根据窗口为原点进行偏移定位的,也就是说它不会根据滚动条的滚动而进行偏移。
z-index属性:
z-index,又称为对象的层叠顺序,它用一个整数来定义堆叠的层次,整数值越大,则被层叠在越上面,
固然这是指同级元素间的堆叠,若是两个对象的此属性具备一样的值,那么将依据它们在HTML文档中流的顺序层叠,
写在后面的将会覆盖前面的。须要注意的是,父子关系是没法用z-index来设定上下关系的,必定是子级在上父级在下。
Note:使用static 定位或无position定位的元素z-index属性是无效的。
相关文章:
http://blog.163.com/love_heartbreaking/blog/static/124561901201211334714800/
http://www.cnblogs.com/snandy/archive/2012/04/23/2455787.html