-
Notifications
You must be signed in to change notification settings - Fork 8.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[zh-TW]: update CSS/box-sizing (#25015)
- Loading branch information
Showing
1 changed file
with
76 additions
and
24 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,68 +1,120 @@ | ||
--- | ||
title: box-sizing | ||
slug: Web/CSS/box-sizing | ||
l10n: | ||
sourceCommit: 4e508e2f543c0d77c9c04f406ebc8e9db7e965be | ||
--- | ||
|
||
{{CSSRef}}{{SeeCompatTable}} | ||
{{CSSRef}} | ||
|
||
The **`box-sizing`** property is used to alter the default [CSS box model](/zh-TW/docs/Web/CSS/CSS_box_model/Introduction_to_the_CSS_box_model) used to calculate width and height of the elements. It is possible to use this property to emulate the behavior of browsers that do not correctly support the CSS box model specification. | ||
**`box-sizing`** [CSS](/zh-TW/docs/Web/CSS) 屬性設定如何計算元素的總寬度與高度。 | ||
|
||
**`box-sizing`** 屬性用於更改預設 [CSS 盒子模型](/zh-TW/docs/Web/CSS/CSS_box_model/Introduction_to_the_CSS_box_model)中所計算的寬度和高度。可以使用此屬性來模擬不正確支持 CSS 盒子模型規範的瀏覽器的行為。 | ||
{{EmbedInteractiveExample("pages/css/box-sizing.html")}} | ||
|
||
{{cssinfo}} | ||
在 [CSS 盒模型](/zh-TW/docs/Web/CSS/CSS_box_model/Introduction_to_the_CSS_box_model)中,預設情況下,你為元素指定的 `width` 和 `height` 只應用於元素的內容區域。如果元素有邊框或內邊距,這些會加到 `width` 和 `height` 上,從而得出畫面上呈現的盒子大小。這意味著當你設定 `width` 和 `height` 時,必須調整你給的值以考慮邊框或內邊距。例如,如果你有四個設為 `width: 25%;` 的盒子,若其中任何一個有左右內邊距或左右邊框,預設情況下它們將無法在父容器的限制內排成一行。 | ||
|
||
`box-sizing` 屬性可用來調整此行為: | ||
|
||
- `content-box` 是預設的 CSS 盒模型行為。如果你將元素的寬度設定為 100 像素,則元素的內容框將是 100 像素寬,任何邊框或內邊距的寬度將加到最終的呈現寬度上,使元素寬度超過 100 像素。 | ||
- `border-box` 告訴瀏覽器將任何邊框和內邊距計算在元素的寬度和高度內。如果你將元素的寬度設定為 100 像素,則這 100 像素將包括任何添加的邊框或內邊距,內容框會縮小以吸收這些額外的寬度。這通常使元素的尺寸調整變得更加容易。 | ||
|
||
## 句法 | ||
`box-sizing: border-box` 是瀏覽器對 {{htmlelement("table")}}、{{htmlelement("select")}}、{{htmlelement("button")}} 元素,以及對 `{{htmlelement("input/radio", "radio")}}`、`{{htmlelement("input/checkbox", "checkbox")}}`、`{{htmlelement("input/reset", "reset")}}`、`{{htmlelement("input/button", "button")}}`、`{{htmlelement("input/submit", "submit")}}`、`{{htmlelement("input/color", "color")}}` 或 `{{htmlelement("input/search", "search")}}` 類型的 {{htmlelement("input")}} 元素所使用的預設樣式。 | ||
|
||
> [!NOTE] | ||
> 將 `box-sizing` 設為 `border-box` 通常對元素佈局非常有用。這可以讓元素尺寸處理更容易,並消除許多在佈局內容時可能遇到的問題。然而,當使用 `position: relative` 或 `position: absolute` 時,使用 `box-sizing: content-box` 可以使定位值與內容相關,並獨立於邊框和內邊距尺寸的變化,這在某些情況下可能是理想的。 | ||
## 語法 | ||
|
||
```css | ||
/* Keyword values */ | ||
box-sizing: content-box; | ||
box-sizing: border-box; | ||
box-sizing: content-box; | ||
|
||
/* Global values */ | ||
/* 全域值 */ | ||
box-sizing: inherit; | ||
box-sizing: initial; | ||
box-sizing: revert; | ||
box-sizing: revert-layer; | ||
box-sizing: unset; | ||
``` | ||
|
||
`box-sizing` 屬性是從以下值列表中選擇的單一關鍵字。 | ||
|
||
### 值 | ||
|
||
- `content-box` | ||
- : 這是根據 CSS 標準的起始值和預設值。 {{Cssxref("width")}} 與 {{Cssxref("height")}} 只包括內容本身的寬和高, 不包括邊框(border)、內邊距(padding)、外邊距(margin)。注意:內邊距、邊框和外邊距都在這個盒子的外部。例如,如果 `.box {width: 350px};` 而且 `{border: 10px solid black;}`,那麼在瀏覽器中的渲染該容器的實際寬度將是 370px,簡單來說,尺寸計算公式:width = 內容的寬度,height = 內容的高度。寬度和高度都不包含內容的邊框(border)和內邊距(padding)。 | ||
|
||
- : 這是 CSS 標準指定的初始值和預設值。{{Cssxref("width")}} 和 {{Cssxref("height")}} 屬性包含內容,但不包括內邊距、邊框或外邊距。例如,`.box {width: 350px; border: 10px solid black;}` 會呈現寬度為 370px 的盒子。 | ||
|
||
此時,元素的尺寸計算為:_寬度 = 內容的寬度_,_高度 = 內容的高度_。(邊框和內邊距不包括在計算中。) | ||
|
||
- `border-box` | ||
|
||
- : {{Cssxref("width")}} 和 {{Cssxref("height")}} 屬性包括內容(content),內邊距(padding)和邊框(border),但不包括外邊距(margin)。這是當文檔處於 Quirks 模式時 Internet Explorer 所使用的[盒模型](/zh-TW/docs/Web/CSS/CSS_box_model/Introduction_to_the_CSS_box_model)。注意,內邊距和邊框都將在盒子內 ,例如,`.box {width: 350px; border: 10px solid black;}`,渲染出的容器寬度會固定在 350px,而內容(content)的寬度就會變成 330px,因為邊框(border)佔了 20px。內容框不能為負,並且進位到 0,使得不可能使用 border-box 使元素消失。 | ||
- : {{Cssxref("width")}} 和 {{Cssxref("height")}} 屬性包含內容、內邊距和邊框,但不包括外邊距。請注意,內邊距和邊框會在盒子內。例如,`.box {width: 350px; border: 10px solid black;}` 會呈現寬度為 350px 的盒子,其中內容區域的寬度為 330px。內容框的寬度不能為負數,最小值為 0,因此無法使用 `border-box` 使元素消失。 | ||
|
||
這裡的維度計算為: | ||
此時,元素的尺寸計算為:_寬度 = 邊框 + 內邊距 + 內容的寬度_,_高度 = 邊框 + 內邊距 + 內容的高度_。 | ||
|
||
_width = border + padding + 內容的 width_, | ||
_height = border + padding + 內容的 height_。 | ||
## 形式定義 | ||
|
||
- `padding-box` {{non-standard_inline}} {{deprecated_inline}} | ||
- : The {{Cssxref("width")}} and {{Cssxref("height")}} properties include the content, the padding but neither the border, nor the margin. Only Firefox implemented this value, and it was removed in Firefox 50. | ||
{{cssinfo}} | ||
|
||
### Formal syntax | ||
## 形式語法 | ||
|
||
{{csssyntax}} | ||
|
||
## Examples | ||
## 範例 | ||
|
||
### 使用 content-box 和 border-box 的盒子尺寸 | ||
|
||
此範例展示了不同的 `box-sizing` 值如何改變兩個其他條件相同的元素的呈現尺寸。 | ||
|
||
#### HTML | ||
|
||
```html | ||
<div class="content-box">Content box</div> | ||
<br /> | ||
<div class="border-box">Border box</div> | ||
``` | ||
|
||
#### CSS | ||
|
||
```css | ||
/* support Firefox, Chrome, Safari, Opera, IE8+ and old Android */ | ||
div { | ||
width: 160px; | ||
height: 80px; | ||
padding: 20px; | ||
border: 8px solid red; | ||
background: yellow; | ||
} | ||
|
||
.content-box { | ||
box-sizing: content-box; | ||
/* 總寬度: 160px + (2 * 20px) + (2 * 8px) = 216px | ||
總高度: 80px + (2 * 20px) + (2 * 8px) = 136px | ||
內容框寬度: 160px | ||
內容框高度: 80px */ | ||
} | ||
|
||
.example { | ||
-moz-box-sizing: border-box; | ||
.border-box { | ||
box-sizing: border-box; | ||
/* 總寬度: 160px | ||
總高度: 80px | ||
內容框寬度: 160px - (2 * 20px) - (2 * 8px) = 104px | ||
內容框高度: 80px - (2 * 20px) - (2 * 8px) = 24px */ | ||
} | ||
``` | ||
|
||
## Specifications | ||
#### 結果 | ||
|
||
{{EmbedLiveSample('Box_sizes_with_content-box_and_border-box', "使用 content-box 和 border-box 的盒子尺寸", 'auto', 300)}} | ||
|
||
## 規範 | ||
|
||
{{Specifications}} | ||
|
||
## Browser compatibility | ||
## 瀏覽器相容性 | ||
|
||
{{Compat}} | ||
|
||
## See also | ||
## 參見 | ||
|
||
- [CSS box model](/zh-TW/docs/Web/CSS/CSS_box_model/Introduction_to_the_CSS_box_model) | ||
- [CSS 盒模型](/zh-TW/docs/Web/CSS/CSS_box_model/Introduction_to_the_CSS_box_model) |