定義
CSS把每個元素看成是一個個單獨的框,這裡就叫它“元素框”吧。而CSS 盒子模型 (Box Model) 可以了解成一種規範,它規定了元素框處理其“最裡邊的内容區域(例如文本,圖像等)”、“内容周圍填充的區域”、“邊框” 和“邊界區域”的方式。
PS: 為了友善區分概念,通常也會把“填充”叫做“内邊距”,把“邊界”叫做“外邊距”。
<a href="https://s1.51cto.com/wyfs02/M01/00/57/wKiom1mauPbRofl6AAAfTAb0_NU590.gif-wh_500x0-wm_3-wmp_4-s_1078774724.gif" target="_blank"></a>
元素框的最内部分是實際的内容,直接包圍内容的是内邊距。内邊距呈現了元素的背景。内邊距的邊緣是邊框。邊框以外是外邊距,外邊距預設是透明的,是以不會遮擋其後的任何元素。
總之,盒子模型由内到外組成: 内容區域(content) --> 填充(padding) --> 邊框(border) --> 邊界(margin)。
在 CSS 中,width 和 height 僅僅指的是内容區域的寬度和高度。
幾個提示
l 背景應用于由内容和内邊距、邊框組成的區域。也就是如果你設定了背景色,那麼内容、内邊距、邊框都會先被背景色填充,然後内容和邊框的顔色會将其覆寫。如果你将内容和邊框的顔色設定成透明色就能看得出來。
l 内邊距、邊框和外邊距可以應用于一個元素的所有邊,也可以應用于單獨的邊。也就是上下左右你可選擇任何一邊設定,或者全部。
l 外邊距可以是負值,而且在很多情況下都要使用負值的外邊距。内邊距不能用負值。
浏覽器相容性
一旦為頁面設定了恰當的 DTD,大多數浏覽器都會按照上面的圖示來呈現内容。然而 IE 5 和 6 的呈現卻是不正确的。根據 W3C 的規範,元素内容占據的空間是由 width/height 屬性設定的,而内容周圍的 padding 和 border 值是另外計算的。不幸的是,IE5.X 和 6 使用自己的非标準模型。這些浏覽器的 width /height屬性不隻是内容的寬度,而是内容、内邊距和邊框的寬度的總和。
雖然有方法解決這個問題。但是目前最好的解決方案是回避這個問題。也就是,不要給元素添加具有指定寬度的内邊距,而是嘗試将内邊距或外邊距添加到元素的父元素和子元素。
PS:如果對你有幫助,就順手點個贊吧~
本文轉自 藝晨光 51CTO部落格,原文連結:http://blog.51cto.com/ycgit/1958121,如需轉載請自行聯系原作者