Latest web development tutorials

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 中)。

這個是個較小的框(width 為300px ,height 為100px)。

這個是個較大的框(width 為300px ,height 為100px)。

以上兩個<div> 元素雖然寬度與高度設置一樣,但真實展示的大小不一致,因為div2 指定了內邊距:

實例

.div1 {
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 現在是一樣大小的!

本教程!

以下是兩個<div>元素添加box-sizing: border-box;屬性的簡單實例。

實例

.div1 {
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;
}

嘗試一下»