定義瀏覽器
CSS把每一個元素當作是一個個單獨的框,這裏就叫它「元素框」吧。而CSS 盒子模型 (Box Model) 能夠理解成一種規範,它規定了元素框處理其「最裏邊的內容區域(例如文本,圖像等)」、「內容周圍填充的區域」、「邊框」 和「邊界區域」的方式。ide
PS: 爲了方便區分概念,一般也會把「填充」叫作「內邊距」,把「邊界」叫作「外邊距」。spa
元素框的最內部分是實際的內容,直接包圍內容的是內邊距。內邊距呈現了元素的背景。內邊距的邊緣是邊框。邊框之外是外邊距,外邊距默認是透明的,所以不會遮擋其後的任何元素。get
總之,盒子模型由內到外組成: 內容區域(content) --> 填充(padding) --> 邊框(border) --> 邊界(margin)。it
在 CSS 中,width 和 height 僅僅指的是內容區域的寬度和高度。io
幾個提示class
l 背景應用於由內容和內邊距、邊框組成的區域。也就是若是你設置了背景色,那麼內容、內邊距、邊框都會先被背景色填充,而後內容和邊框的顏色會將其覆蓋。若是你將內容和邊框的顏色設置成透明色就能看得出來。瀏覽器兼容性
l 內邊距、邊框和外邊距能夠應用於一個元素的全部邊,也能夠應用於單獨的邊。也就是上下左右你可選擇任何一邊設置,或者所有。兼容性
l 外邊距能夠是負值,並且在不少狀況下都要使用負值的外邊距。內邊距不能用負值。model
瀏覽器兼容性
一旦爲頁面設置了恰當的 DTD,大多數瀏覽器都會按照上面的圖示來呈現內容。然而 IE 5 和 6 的呈現倒是不正確的。根據 W3C 的規範,元素內容佔據的空間是由 width/height 屬性設置的,而內容周圍的 padding 和 border 值是另外計算的。不幸的是,IE5.X 和 6 使用本身的非標準模型。這些瀏覽器的 width /height屬性不僅是內容的寬度,而是內容、內邊距和邊框的寬度的總和。
雖然有方法解決這個問題。可是目前最好的解決方案是迴避這個問題。也就是,不要給元素添加具備指定寬度的內邊距,而是嘗試將內邊距或外邊距添加到元素的父元素和子元素。
PS:若是對你有幫助,就順手點個贊吧~