CSS 框模型

CSS 框模型(Box Model)

所有HTML元素可以看作盒子,在CSS中,"box model"这一术语用来设计和布局。

CSS盒模型本质上是一个盒子,封装周围的HTML元素,它包括:边距,边框,填充,和实际内容。

盒模型允许在其它元素和周围元素边框之间的空间放置元素。

下面的图片说明了框模型(Box Model):

CSS box-model

不同部分的说明:

  • Margin - 清除边框区域。Margin没有背景颜色,完全透明
  • Border - 边框周围的填充和内容。边框受到盒子的背景颜色影响
  • Padding - 清除内容周围的区域。会受到框中填充的背景颜色影响
  • Content - 盒子的内容,显示文本和图像

要在所有浏览器中的元素的宽度和高度设置正确,需要知道盒模型如何工作。

元素的宽度和高度

重要: 当指定一个CSS元素的宽度和高度属性时,只是设置内容区域的宽度和高度。而,完全大小的元素,还必须添加填充,边框和边距。

下面的例子中,元素的总宽度为300px:

 width:250px;
 padding:10px;
 border:5px solid gray;
 margin:10px; 

这样计算: 250px (宽) + 20px (left + 右填充) + 10px (left + 右边框) + 20px (left + 右边距) = 300px

试想,只有250像素的空间。若设置总宽度为250像素的元素:

 width:220px;
 padding:10px;
 border:5px solid gray;
 margin:0px; 

最终元素的总宽度计算公式:

总元素宽度 = 宽度 + 左填充 + 右填充 + 左边框 + 右边框 + 左边距 + 右边距

元素的总高度最终计算公式:

总元素的高度 = 高度 + 顶部填充 + 底部填充 + 上边框 + 下边框 + 上边距 + 下边距

浏览器兼容问题

一旦为页面设置了恰当的 DTD,大多数浏览器都会按照上面的图示呈现内容。然而 IE 5 和 6 的呈现却不正确。根据 W3C 的规范,元素内容占据的空间是由 width 属性设置的,而内容周围的 padding 和 border 值是另外计算的。不幸的是,IE5.X 和 6 在怪异模式中使用自己的非标准模型。这些浏览器的 width 属性不是内容的宽度,而是内容、内边距和边框的宽度的总和。

虽然有方法解决这个问题。但是目前最好的解决方案是回避这个问题。也就是,不要给元素添加具有指定宽度的内边距,而是尝试将内边距或外边距添加到元素的父元素和子元素。

IE8 及更早IE版本不支持 填充的宽度和边框的宽度属性设。

解决IE8及更早版本不兼容问题可以在HTML页面声明 <!DOCTYPE html>即可。