什么是CSS盒模型
当对一个文档进行布局的时候,浏览器的渲染引擎会根据标准之一的 CSS 基础框盒模型,将所有元素表示为一个个矩形的盒子(box)。CSS 决定这些盒子的大小、位置以及属性(例如颜色、背景、边框尺寸…)。
每个盒子由四个部分(或称区域)组成,其效用由它们各自的边界(Edge)所定义。如图,与盒子的四个组成区域相对应,每个盒子有四个边界:1. 外边框边界 Margin Edge、2. 边框边界 Border Edge、3. 内边距边界 Padding Edge、4. 内容边界 Content edge。
盒模型的四个部分:
外边距区域 margin area 由外边距边界限制,用空白区域扩展边框区域,以分开相邻的元素。它的尺寸为 margin-box 宽度 和 margin-box 高度。
外边距区域的大小由
margin-top、margin-right、margin-bottom、margin-left,和简写属性margin控制。在发生外边距合并(margin合并如何清除)的情况下,由于盒之间共享外边距,外边距不容易弄清楚。
边框区域 border area 由边框边界限制,扩展自内边距区域,是容纳边框的区域。其尺寸为 border-box 宽度 和 border-box 高度。
边框的粗细由
border-width和简写的border属性控制。如果box-sizing属性被设为border-box,那么边框区域的大小可明确地通过width、min-width,max-width、height、min-height,和max-height属性控制。假如框盒上设有背景(background-color或background-image),背景将会一直延伸至边框的外沿(默认为在边框下层延伸,边框会盖在背景上)。此默认表现可通过 CSS 属性background-clip来改变。
内边距区域 padding area 由内边距边界限制,扩展自内容区域,负责延伸内容区域的背景,填充元素中内容与边框的间距。它的尺寸是 padding-box 宽度 和 padding-box 高度。
内边距的粗细可以由
padding-top、padding-right、padding-bottom、padding-left,和简写属性padding控制。
内容区域 content area ,由内容边界限制,容纳着元素的“真实”内容,例如文本、图像,或是一个视频播放器。它的尺寸为内容宽度(或称 content-box 宽度)和内容高度(或称 content-box 高度)。
如果
box-sizing为content-box(默认),则内容区域的大小可明确地通过width、min-width、max-width、height、min-height,和max-height控制。