CSS 框模型概述

SS 框模型 (Box Model) 規定了元素框處理元素內容、內邊距邊框 和 外邊距 的方式。css

CSS 框模型概述

CSS 框模型

元素框的最內部分是實際的內容,直接包圍內容的是內邊距。內邊距呈現了元素的背景。內邊距的邊緣是邊框。邊框之外是外邊距,外邊距默認是透明的,所以不會遮擋其後的任何元素。瀏覽器

提示:背景應用於由內容和內邊距、邊框組成的區域。spa

內邊距、邊框和外邊距都是可選的,默認值是零。可是,許多元素將由用戶代理樣式表設置外邊距和內邊距。能夠經過將元素的 margin 和 padding 設置爲零來覆蓋這些瀏覽器樣式。這能夠分別進行,也可使用通用選擇器對全部元素進行設置:翻譯

* {
  margin: 0;
  padding: 0;
}

在 CSS 中,width 和 height 指的是內容區域的寬度和高度。增長內邊距、邊框和外邊距不會影響內容區域的尺寸,可是會增長元素框的總尺寸。代理

假設框的每一個邊上有 10 個像素的外邊距和 5 個像素的內邊距。若是但願這個元素框達到 100 個像素,就須要將內容的寬度設置爲 70 像素,請看下圖:element

CSS 框模型實例

#box {
  width: 70px;
  margin: 10px;
  padding: 5px;
}

提示:內邊距、邊框和外邊距能夠應用於一個元素的全部邊,也能夠應用於單獨的邊。get

提示:外邊距能夠是負值,並且在不少狀況下都要使用負值的外邊距。瀏覽器兼容性

瀏覽器兼容性

一旦爲頁面設置了恰當的 DTD,大多數瀏覽器都會按照上面的圖示來呈現內容。然而 IE 5 和 6 的呈現倒是不正確的。根據 W3C 的規範,元素內容佔據的空間是由 width 屬性設置的,而內容周圍的 padding 和 border 值是另外計算的。不幸的是,IE5.X 和 6 在怪異模式中使用本身的非標準模型。這些瀏覽器的 width 屬性不是內容的寬度,而是內容、內邊距和邊框的寬度的總和。兼容性

雖然有方法解決這個問題。可是目前最好的解決方案是迴避這個問題。也就是,不要給元素添加具備指定寬度的內邊距,而是嘗試將內邊距或外邊距添加到元素的父元素和子元素。方法

術語翻譯

  • element : 元素。
  • padding : 內邊距,也有資料將其翻譯爲填充。
  • border : 邊框。
  • margin : 外邊距,也有資料將其翻譯爲空白或空白邊。

在 w3school,咱們把 padding 和 margin 統一地稱爲內邊距和外邊距。邊框內的空白是內邊距,邊框外的空白是外邊距,很容易記吧:)

相關文章
相關標籤/搜索