首先明确框模型中的边界在哪里:
根据规范,当一个元素的定位为绝对定位的时候,它的包含块由它定位属性为relative、absolute、fixed的祖先元素来创建。但是又根据祖先元素属性不同来划分包含块大小。分为两种情况:
1.当它的祖先元素是内联元素(即行内元素)的时候,而且文本方向是从左往右的话(即direction属性为ltr。这里要注意的是这个属性并不会将文字的书写方式改变,具体文字的书写方式在Unicode中定义。这个属性会改变一些布局。),它的包含块的顶、左边是祖先元素生成的第一个框的顶、左内边距边界(padding edges) ,右、下边是祖先元素生成的最后一个框的右、下内边距边界(padding edges) 。如果它的文字方向是从左往右(即rtl),那么包含块的顶、右边是祖先元素生成的第一个框的顶、右内边距边界(padding edges) ,左、下边是祖先元素生成的最后一个框的左、下内边距边界(padding edges) 。
2.如果它的祖先元素是块级元素的时候,那么它的包含块的区域是祖先元素的内边距边界(padding edges)。
但是谷歌浏览器和火狐浏览器对第一条的解释不太一样:
<p style="border:1px solid yellow; width:200px; padding:20px;">
T
<span style="background-color:#C0C0C0; position:relative;padding:10px;line-height:4;border:1px red solid">
这段文字从左向右排列,红 XX 和 蓝 XX 和黄 XX 都是绝对定位元素,它的包含块是相对定位的SPAN。
可以通过它们绝对定位的位置来判断它们包含块的边缘。
<em style="position:absolute; color:red; top:0; left:0;">XX</em>
<em style="position:absolute; color:green; top:20px; left:0;">XX</em>
<em style="position:absolute; color:blue; bottom:0; right:0;">XX</em>
</span>
</p>
显示的结果:
谷歌:
火狐浏览器:
这个要稍微注意一下。
另外,当时用绝对定位的时候,没有给属性top、left、right、bottom赋值的话,那么它会相对于包含块保持在原来的位置。