绝对定位的时候它的包含块到底是什么

首先明确框模型中的边界在哪里:

根据规范,当一个元素的定位为绝对定位的时候,它的包含块由它定位属性为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赋值的话,那么它会相对于包含块保持在原来的位置。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值