上个帖子中对可视化格式模型做了一个概述,并简单的介绍了一下包含块的概念,在这里:【分享】说说标准 --CSS中非常重要的可视化格式模型(visual formatting model)简介 。
这个帖子会就包含块的细节给出详细的讲解。
上回贴说到,一个元素box的定位和尺寸,有时候会跟某一矩形框有关,这个矩形框,就被称作元素的包含块。而元素会为它的子孙元素创建包含块,那么,是不是说,元素的包含块就是它的父元素呢?答案是否定的,这是一个误区。也正因为如此,才会有专门的一帖来说明它。
一个元素包含块的确定,跟元素自身和它的祖先元素的样式等有关系。
根元素的包含块
根元素,就是处于文档树最顶端的元素,它没有父节点。
根元素存在的包含块,被叫做初始包含块 (initial containing block)。具体,跟用户端有关。
●在(X)HTML中,根元素是html元 素(尽管有的浏览器会不正确地使用body元 素)。
●而初始包含块的direction属性与根元素相同。
“static”和”relative”定位的元素
对于其它元素:如果该元素的定位(position)为 “relative” (相对定位)或者 “static”(静态定位),它的包含块由它最近的块级、单元格 (table cell)或者行内块(inline-block)祖先元素的内容框创建。
关于内容框,见:【分享】说说标准 —— 你真的了解盒子模型(box model)吗?
元素如果未声明 “position” 特性 ,那么就会采用 “position” 的默认值 ”static”。所以,一般元素都是静态定位的。
比如:
- HTML code
<table id="table1"> <tr> <td id="td1"> <div id="div1" style="padding:20px;border:1px solid red;"> <span> <strong id=”greed” style="position:relative;">greed is</strong> good 999999 </span> </div> </td> </tr></table>
SPAN元素中包含的文本在div1中的位置可以看出,div1创建的包含块的区域是它的内容边界,也就是内边界。
“position:fixed” 定位的元素
如果元素是固定定位 (“position:fixed”) 元素,那么它的包含块是当前可视窗口。
'position: absolute' 定位的元素
如果元素是绝对定位(”position: absolute”)元素,包含块由离它最近的 position 属性为 “absolute”、“relative” 或者 “fixed” 的祖先元素创建。
1. 如果其祖先元素是行内元素,则包含块取决于其祖先元素的 “direction” 特性
● 如果 'direction' 是 'ltr',包含块的顶、左边是祖先元素生成的第一个框的顶、左内边距边界(padding edges) ,右、下边是祖先元素生成的最后一个框的右、下内边距边界(padding edges) 。
例如:
- HTML code
<p style="border:1px solid red; width:200px; padding:20px;"> T <span style="background-color:#C0C0C0; position:relative;"> 这段文字从左向右排列,红 XX 和 蓝 XX 和黄 XX 都是绝对定位元素,它的包含块是相对定位的SPAN。 可以通过它们绝对定位的位置来判断它们包含块的边缘。 <em style="position:absolute; color:red; top:0; left:0;">XX</em> <em style="position:absolute; color:yellow; top:20px; left:0;">XX</em> <em style="position:absolute; color:blue; bottom:0; right:0;">XX</em> </span></p>
图示:
行内元素内形成的包含块,在各浏览器中各不相同,存在兼容性问题。可以通过上面的例子可以证明这一点。蓝色的 “XX”的位置在各浏览器中都不一样。你可以打开浏览器试一下。
当行框是这样的时候,比较纠结:
- HTML code
<p style="border:1px solid red; width:200px; padding:20px;"> TEXT TEXT TEXT <span style="background-color:#C0C0C0; position:relative;"> 这段文字从左向右排列,红 XX 和 蓝 XX 和黄 XX 都是绝对定位元素,它的包含块是相对定位的SPAN。 可以通过它们绝对定位的位置来判断它们包含块的边缘。 <em style="position:absolute; color:red; top:0; left:0;">XX</em> <em style="position:absolute; color:yellow; top:20px; left:0;">XX</em> <em style="position:absolute; color:blue; bottom:0; right:0;">XX</em> </span></p>
这时,会造成包含块的宽度为负。这时,绝对定位元素定位起来,肯定也很纠结。
● 如果 'direction' 是 'rtl',包含块的顶、右边是祖先元素生成的第一个框的顶、右内边距边界(padding edges) ,左、下边是祖先元素生成的最后一个框的左、下内边距边界(padding edges) 。
例如:
- HTML code