常规流
盒模型:规定单个盒子的规则
视觉格式化模型(布局规则):页面中的多个盒子排列规则
视觉格式化模型,大体上将页面中盒子的排列方式分为三种:
- 常规流
- 浮动
- 定位
常规流布局
常规流 、文档流、普通文档流、常规文档流
所有元素,默认情况下,都属于常规流布局
总体规则:块盒独占一行,行盒水平依次排列
包含块(containing block):每个盒子都有它的包含块,包含块决定了盒子的排列区域
绝大部分情况下:盒子的包含块,为其父元素的内容盒
块盒
- 每个块盒的总宽度,必须刚好等于包含块的宽度
[水平方向上]
width的默认值是auto
auto:将剩余空间吸收掉
margin的取值也可以是auto,默认值为0
width吸收能量强于margin
若宽度、边框、内边距、外边距计算后仍有剩余空间,该剩余空间被margin-right全部吸收(right与文字排列方式从左到右有关)
/* 非常常见的居中方式 */
margin-left: auto;
margin-right: auto;
在常规流中,块盒在其包含块中,可以定宽,任何左右margin设置为auto
/* 水平居中 */
margin: 0 auto;
-
每个块盒垂直方向上的auto值
height: auto 表示适应内容的高度(自适应)
margin: auto 表示0 -
百分比取值
padding、宽(高)、margin可以取值为百分比
以上的所有百分比相对于包含块的宽度
高度的百分比:
-
包含块的高度是否取决于子元素的高度,设置百分比无效
-
包含块的高度不取决于子元素的高度,百分比相对于父元素高度
-
上下外边距的合并
两个常规流块盒,上下外边距相邻(条件),会进行合并,两个外边距取最大值(父子元素之间也会进行合并只要符合条件)
解决该问题: 1.设置padding 2.使外边距不相邻(例如加border)