开心小窝

一个记录日常学习且神奇的地方

CSS - 常规流

常规流

盒模型:规定单个盒子的规定

视觉格式化模型(布局规则):页面中的多个盒子排列规则

视觉格式化模型,大体上将页面中盒子的排列分为三种方式

1.常规流

2.浮动

3.定位

常规流布局

常规流,文档流,普通文档流,常规文档流

所有元素,默认情况下,都属于常规流布局

总体规则:块盒独占一行,行盒水平依次排序

包含块(containing block):每个盒子都有它的包含块,包含块决定了盒子的排列区域

绝大部分情况下:盒子的包含块,为其父元素的内容盒

块盒

1.每个块盒的总宽度,必须刚好等于包含块的宽度

宽度的默认值是auto

margin的取值也可以是auto,默认值0

auto:将剩余空间吸收掉

width吸收能力强于auto

若宽度,边框,内边距,外边距计算后,仍有剩余空间,该空间被margin-right吸收

2.每个块盒垂直方向上的auto的值

height:auto,适应内容的高度

margin:auto,表示0

3.百分比取值

padding,宽,margin可以取值为百分比

以上的所有百分比相对于包含块的宽度

高度的百分比

1).包含块的高度是否取决于子元素的高度,设置百分比无效

2).包含块的高度不取决于子元素的高度,把百分比相对于父类元素高度

4.上下外边距的合并

两个常规流盒,上下外边距相邻,会进行合并

两个外边距取最大值