常规流
盒模型:规定单个盒子的规则
视觉格式化模型(布局规则):页面中多个盒子的排列规则
视觉格式化模型,大体上将页面中盒子的排列分为三种方式:
- 常规流
- 浮动
- 定位
常规流布局
常规流的叫法:++常规流、普通文档流、常规文档流++
所有元素,默认情况下,都属于常规流布局
总体规则:块盒独占一行,行盒水平依次排列
包含块(containing block):每个盒子都有它的包含块,包含块决定了盒子的排列区域
绝大部分情况下,盒子的包含块,为其父元素的内容盒
块盒
- 每个块盒的总宽度,必须刚好等于包含块的宽度
宽度的默认值为auto
margin的取值也可以为auto,但默认值为0
atuo:将剩余空间吸收掉
若有剩余空间,且当width和margin同时设置auto时,width会吸收掉剩余空间,width比margin的吸收能力强
- 每个块盒垂直方向上的auto值
height:auto,适应内容的高度
margin:auto,表示0
- 百分比取值
padding、宽、margin可以取值为百分比
以上的所有百分比相对于包含块的宽度
高的值也可以为百分比
1).包含块的高度是否取决于子元素的高度,设置百分比无效
父元素{
没有设置高度
}
子元素{
height:50%;/*无效百分比*/
}
2).包含块的高度不取决于子元素的高度,百分比相对于父元素的高度
父元素{
height:1000px;
}
子元素{
height:50%;/*此时高度为500px*/
}
- 上下外边距的合并
两个常规流块盒(兄弟盒或父子盒),上下外边距相邻,会进行合并
外边距会取两盒中的较大值
可采用padding或border的方式解决此问题