CSS3 框大小
CSS3 box-sizing
屬性可以設置 width 和 height 屬性中包含了 padding(內邊距) 和 border(邊框)。
流覽器支持
表格中的數字表示支持該屬性的第一個流覽器的版本號。
緊跟在數字後面的 -webkit- 或 -moz- 為指定流覽器的首碼。
屬性 | |||||
---|---|---|---|---|---|
box-sizing | 10.0 4.0 -webkit- |
8.0 | 29.0 2.0 -moz- |
5.1 3.1 -webkit- |
9.5 |
不使用 CSS3 box-sizing 屬性
默認情況下,元素的寬度與高度計算方式如下:
width(寬) + padding(內邊距) + border(邊框) = 元素實際寬度
height(高) + padding(內邊距) + border(邊框) = 元素實際高度
這就意味著我們在設置元素的 width/height 時,元素真實展示的高度與寬度會更大(因為元素的邊框與內邊距也會計算在 width/height 中)。
以上兩個 <div> 元素雖然寬度與高度設置一樣,但真實展示的大小不一致,因為 div2 指定了內邊距:
實例
width: 300px;
height: 100px;
border: 1px solid blue;
}
.div2 {
width: 300px;
height: 100px;
padding: 50px;
border: 1px solid red;
}
使用這種方式如果想要獲得較小的那個框且包含內邊距,就不得不考慮到邊框和內邊距的寬度。
CSS3 的 box-sizing
屬性很好的解決了這個問題。
使用 CSS3 box-sizing 屬性
CSS3 box-sizing
屬性在一個元素的 width 和 height 中包含 padding(內邊距) 和 border(邊框)。
如果在元素上設置了 box-sizing: border-box;
則 padding(內邊距) 和 border(邊框) 也包含在 width 和 height 中:
以下是兩個 <div> 元素添加 box-sizing: border-box;
屬性的簡單實例。
實例
width: 300px;
height: 100px;
border: 1px solid blue;
box-sizing: border-box;
}
.div2 {
width: 300px;
height: 100px;
padding: 50px;
border: 1px solid red;
box-sizing: border-box;
}
從結果上看 box-sizing: border-box;
效果更好,也正是很多開發人員需要的效果。
以下代碼可以讓所有元素以更直觀的方式展示大小。很多流覽器已經支持 box-sizing: border-box;
(但是並非所有 - 這就是為什麼
input 和 text 元素設置了 width: 100%; 後的寬度卻不一樣)。
所有元素使用 box-sizing 是比較推薦的:
實例
box-sizing: border-box;
}