【Daily】css 定位详解

css position: absolute、relative详解

position: absolute 
将对象从文档流中拖出,使用left,right,top,bottom 等属性相对于其最接近的一个最有定位设置的父对象进行绝对定位。如果不存在这样的父对象,则依据body对象。而其层叠通过z-index属性定义,z-index值为无单位的整数,大的在最上面,可以有负值
此时对象不具有外补丁( margin ),但仍有内补丁( padding )和边框( border )。 
要激活对象的绝对(absolute)定位,必须指定 left , right , top , bottom 属性中的至少一个。否则上述属性会使用他们的默认值 auto ,这将导致对象遵从正常的HTML布局规则,在前一个对象之后立即被呈递

position: relative
参照父级(最近)的内容区的左上角为原始点结合TRBL属性(TOP、RIGHT、BOTTOM、LEFT)进行定位(或者相对于被定位元素在父级内容区中的上一个元素进行偏移),无父级则以BODY的左上角为原始点。相对定位是不能层叠的。在使用相对定位时,无论元素是否进行移动,元素依然占据原来的空间。因此,移动元素会导致它覆盖其他框。 同样可以用z-index分层设计。


多个position嵌套时:
position的属性值的效果,直接受其容器样式中position属性值影响。
例如如下A-B的嵌套结构
<div id="A">
 <div id="B">
 </div>
</div>
当A的position为relative时,B的position为absolute才有效。这时候left:0、top:0就不再针对窗口文档,而是针对id为A的这个div了。
http://www.awflasher.com/blog/archives/731

从应用的角度来说,relative常用于包含有absolute元素的容器元素上。 
absolute元素默认以body做为容器元素进行绝对定位。 
如果你想在页面一个特定区域进行绝对定位,就可以在absolute元素外包裹一层容器元素应用relative样式。



CSS普通流:
当浏览器开始渲染 HTML 文档,它从窗口的顶端开始,经过整个文档内容的过程中,分配元素需要的空间。除非文档的尺寸被 CSS 特别的限定,否则浏览器垂直扩展文档来容纳全部的内容。每个新的块级元素渲染为新行。行内元素则按照顺序被水平渲染直到当前行遇到了边界,然后换到下一行垂直渲染。这个过程被成为普通文档流。



posted @ 2011-09-27 17:03  lost2x  阅读(284)  评论(0编辑  收藏  举报