盒模型与视觉格式化模型深度解析

2024-08-31 16:37:13 浏览数 (1)

一、盒模型与视觉格式化模型

  • 盒模型:规定单个盒子尺寸和位置的规则。
  • 视觉格式化模型(布局规则):页面上多个盒子排列的规则。视觉格式化模型大体上将页面中盒子的排列分为三种方式:常规流、浮动、定位。

二、常规流布局特点

(一)常规流布局概述

所有元素默认情况下都是常规流排列的,也称为常规流布局、文档流、普通文档流或常规文档流。在常规流布局中,块盒独占一行,行盒水平依次排列。

(二)包含块

每个盒子都有其包含块,包含块决定了盒子的排列区域。绝大部分情况下,盒子的包含块为其父的内容盒。

(三)块盒特点

  1. 宽度与包含块关系
    • 每个块盒的总宽度必须刚好等于包含块的宽度。
    • 宽度的默认值是auto
    • margin的取值也可以是auto,默认值是 0。
    • widthmargin都设置为auto时,width吸收能力强,margin吸收能力弱。
    • 若宽度定宽之后,宽度、边框、内边框计算后仍然有剩余空间,该剩余空间被margin-right全部吸收。
    • 在常规流中,块盒在其包含块中居中,可以定宽,然后左右margin设置为auto
  2. 垂直方向的auto
    • height: auto,适应内容的高度。
    • margin: auto,表示 0。
  3. 百分比取值
    • padding、宽度、margin可以取值为百分比,所有这些百分比相对于包含块的宽度。
    • 对于高度的百分比:
      • 如果包含块的高度取决于子元素的高度,设置百分比无效。
      • 如果包含块的高度不取决于子元素的高度,百分比相对于父元素高度。
  4. 上下外边距的合并
    • 两个常规流块盒(包含父子常规流块盒),上下外边距相邻,会进行合并,两个外边距取最大值。
    • 当父子常规流块盒外边距相邻时,可以只给父块盒设置margin-toppadding-top实现想要的效果。

0 人点赞