搜尋

寬度、高度、box-sizing、aspect-ratio

網頁元素產生的容器通常都會有「寬度與高度」,這篇教學會介紹容器的寬度 width、高度 height、max-width、min-width、max-height、min-height 等樣式屬性用法,還會使用 max-content、min-content、fit-content 等屬性值,最後還會介紹 box-sizing 定義寬高顯示方式和 aspect-ratio 根據比例調整寬高。

請先閱讀:容器盒子模型 ( box Model )

快速導覽:

CSS 教學 - 寬度、高度、box-sizing、aspect-ratio

寬度與高度

網頁中大多數的元素都可以調整寬度和高度 ( 顯示類型為 inline 的元素不能調整寬高 ),下方列出可以控制寬度和高度的樣式屬性,這些樣式屬性都沒有繼承特性,通常僅需要 widthheight 就能滿足大多數的情境,但如果在一些「響應式網頁設計 RWD」的應用上,有時會需要透過 max-widthmin-widthmax-heightmin-height 來限制元素的最大和最小長寬 ( 前往閱讀 限制長寬的範圍 )。

樣式屬性 說明
width 寬度
height 高度
max-width 最大寬度
min-width 最小寬度
max-height 最大高度
min-height 最小高度

寬度與高度使用的單位

寬度和高度使用「非負值」的「數字」,並搭配下列各種長度單位作為屬性值 ( 參考 長度與角度單位 ):

長度單位 性質 說明
auto 或不設定 - 由內容自動撐開,或根據內容寬高比例換算。
px 絕對長度 像素。
% 相對長度 父元素寬度或高度的百分比。
em 相對長度 元素本身字體大小的幾倍。
rem 相對長度 根元素字體大小的幾倍。
pt、cm、mm、in 絕對長度 印刷單位。
vw、vh、vmin、vmax 相對長度 相對顯示畫面的寬度或高度。

下方的範例使用不同長度單位設定元素的寬度高度。

線上展示:https://codepen.io/oxxo/pen/WNBWMPQ

<!-- HTML 程式碼 -->
<div class="a">
  <div class="b">px</div>
  <div class="c">%</div>
  <div class="d">em</div>
  <div class="e">rem</div>
</div>

<!-- CSS 程式碼 -->
<style>
  :root {font-size: 30px }       /* 根元素字型大小 */
  div {border: 1px solid #000;}
  .a {
    font-size: 10px;             /* 父元素字型大小 */
    width: 200px;
    height: 300px;
    background: orange;
  }
  .a div {font-size: 20px;}      /* 所有子元素字型大小 */
  .b {
    width: 100px;                /* 使用 px */
    height: 60px;
    background: yellow;
  }
  .c {
    width: 70%;                 /* 200px x 70% = 140px */
    height: 20%;                /* 300px x 20% = 60px */
    background: red;
  }
  .d {
    width: 6em;                /* 20px x 6 = 120px */
    height: 6em;               /* 20px x 6 = 120px */
    background: green;
  }
  .e {
    width: 2rem;                /* 30px x 2= 60px */
    height: 1rem;               /* 30px x 1 = 3px */
    background: cyan;
  }
</style>

CSS 教學 - 寬度、高度、box-sizing - 寬度與高度長度單位

由於「百分比」單位是根據「父元素」的寬度或高度進行計算,如果父元素「沒有指定數值」,就無法正確計算出長度這種狀況特別會影響「高度」樣式就算內容使用「換行」或「撐高」的方式,也無法正確計算高度,主要因為網頁的寬度通常會根據瀏覽器的寬度進行換算,但高度卻得經過內容或其他元素的高度才能計算。

如果元素的高度要使用「百分比 %」為單位,父元素就一定要具有實際的高度數值

下方範例的父元素完全不設定寬高,單純使用子元素的高度和換行元素撐開父元素,可以發現第一個 div 的寬度可以正確計算,但高度因為使用了「百分比」為單位,所以只能依靠內容撐開,不然就會是 0。

線上展示:https://codepen.io/oxxo/pen/ExzJQro

<!-- HTML 程式碼 -->
<div class="a">
  <div class="b">高度用 %</div>
  <div class="c">hello oxxo, good morning!!</div>
  <br/>換行
  <br/>換行
  <br/>換行
  <br/>換行
  <br/>換行
  <br/>換行
</div>

<!-- CSS 程式碼 -->
<style>
  div {border: 1px solid #000;}
  .a {
    background: orange;
    display: inline-block;    /* 父元素完全不設定寬高 */
  }
  .b {
    width: 50%;          /* 被撐開的寬度 x 50% */
    height: 50%;         /* 無法計算高度,只能靠內容撐開,不然就是 0 */
    background: yellow;
  }
  .c {
    height: 50px;        /* 設定高度撐開父元素 */
    background: cyan;
  }
</style>

CSS 教學 - 寬度、高度、box-sizing - 高度設定百分比為單位

不設定寬度或高度、使用 auto 單位

對於「不可置換」元素而言,如果不設定元素的寬度或高度,或使用 auto 作為單位,就會根據元素的「顯示類性」套用寬高的預設值

網頁的元素主要分成兩種,分別是「可置換元素」與「不可置換元素」:

  • 可置換元素:透過 src 數值改變元素內容,同時影響元素容器寬高,常見元素為 img、svg。
  • 不可置換元素:大部分的網頁沒有 src 屬性元素都是不可置換元素。

寬高預設值分成下列幾種:

預設寬度 預設高度 相關顯示類性元素
100% 0 divflexgridflowflow-rootruby-text
0 行內容器高度 inlineinline-*tabletable-*ruby
100% 行內容器高度 list-item

下方的範例呈現不同顯示類型元素在沒有設定寬高,或將寬高設定成 auto 的狀況。

線上展示:https://codepen.io/oxxo/pen/PovgQVM

<!-- HTML 程式碼 -->
display: block;<br>
<div class="a"></div>
<br>display: inline;<br>
<div class="b"></div>
<br>display: inline-block;<br>
<div class="c"></div>
<br>display: flex;<br>
<div class="d"></div>
<br>display: grid;<br>
<div class="e"></div>
<br>display: table;<br>
<div class="f"></div>
<br>display: flow;<br>
<div class="g"></div>
<br>list-item;<br>
<div class="h"></div>

<!-- CSS 程式碼 -->
<style>
  div {border: 1px solid red;}
  .a {display: block;}
  .b {display: inline;}
  .c {display: inline-block;}
  .d {display: flex;}
  .e {display: grid;}
  .f {display: table;}
  .g {display: flow;}
  .h {display: list-item;}
</style>

CSS 教學 - 寬度、高度、box-sizing - 不設定寬度或高度、使用 auto 單位

對於「可置換」元素而言,如果不設定元素的寬度或高度,或使用 auto 作為單位,寬度和高度會套用置換後內容的寬度和高度,如果「只設定高度」或「只設定寬度」,則會根據內容的長寬比例自動計算出沒有設定的數值,下方的範例有四張圖,分別是原圖、只設定寬度、只設定高度、同時設定寬高四種。

線上展示:https://codepen.io/oxxo/pen/QWRPQoN

<!-- HTML 程式碼 -->
<img src="https://steam.oxxostudio.tw/download/css/function-filter-demo.jpg"/>
<img class="a" src="https://steam.oxxostudio.tw/download/css/function-filter-demo.jpg"/>
<img class="b" src="https://steam.oxxostudio.tw/download/css/function-filter-demo.jpg"/>
<img class="c" src="https://steam.oxxostudio.tw/download/css/function-filter-demo.jpg"/>


<!-- CSS 程式碼 -->
<style>
  img {border: 1px solid #000;}  /* 不設定寬高就會採用置換後內容的寬高 */
  .a {width: 100px;}    /* 自動等比例計算高度 */
  .b {height: 112px;}   /* 自動等比例計算寬度 */
  .c {
    width: 200px;
    height: 50px;
  }
</style>

CSS 教學 - 寬度、高度和 box-sizing - 可置換元素設定寬度或高度

限制長寬的範圍

widthheight 設定為「可以自動計算數值」的屬性值時,例如百分比、vw、vh、vmin、vmax、calc 計算...等,常會搭配 max-widthmin-widthmax-heightmin-height 這四個「限制最大與最小長寬」的樣式屬性。

下方範例展示使用 max-widthmin-width 限制元素寬度的效果,雖然將 div 的寬度設定為父元素寬度的 100% 或 10%,但因為限制寬度的最大值和最小值,也就讓寬度無法成為父元素寬度的 100% 或 10%。

線上展示:https://codepen.io/oxxo/pen/WNqKbBN

<!-- HTML 程式碼 -->
<main>
  <div class="a">width:100%</div>
  <div class="a max">width: 100%;<br/>max-width: 200px;</div>
  <div class="b">width:10%</div>
  <div class="b min">width: 100%;<br/>max-width: 200px;</div>
</main>

<!-- CSS 程式碼 -->
<style>
  main {
    border: 1px solid #000;
    width: 300px;
    padding: 0 10px;
  }
  div {
    font-family: monospace;
    border: 1px solid #000;
    padding: 10px;
    margin: 10px 0;
  }
  .a {width: 100%;}
  .max {max-width: 200px;}
  .b {width: 10%;}
  .min {min-width: 200px;}
</style>

CSS 教學 - 寬度、高度和 box-sizing - max-width、min-width 限制元素寬度

同樣的做法,也可以使用 max-heightmin-height 限制高度,但需要注意如果使用百分比為數值,則「父元素一定要有高度單位」,下方範例的父元素使用紅色框線,可以看出子元素的高度限制狀況。

線上展示:https://codepen.io/oxxo/pen/yLdqyWO

<!-- HTML 程式碼 -->
<main>
  <div class="a">height:100%</div>
  <div class="a max">height: 100%;<br/>max-height: 50px;</div>
  <div class="b">height:10%</div>
  <div class="b min">height: 100%;<br/>max-height: 50px;</div>
</main>


<!-- CSS 程式碼 -->
<style>
  main {
    border: 1px solid #f00;
    height: 120px;
  }
  div {
    font-family: monospace;
    border: 1px solid #000;
    margin: 10px 0;
  }
  .a {height: 100%;}
  .max {max-height: 80px;}
  .b {height: 10%;}
  .min {min-height: 80px;}
</style>

CSS 教學 - 寬度、高度和 box-sizing - max-height、min-height 限制元素高度

使用 max-content、min-content、fit-content 屬性值

元素的長寬除了使用單位、百分比和 auto 等常用的屬性值,也可以使用 CSS3 特有的 max-contentmin-contentfit-content 屬性值,這些屬性值的說明如下:

屬性值 說明
max-content 寬度等於內容最大寬度 ( 文字方向垂直時等於最大高度 )。
min-content 寬度等於內容最小寬度 ( 等於最長的單字 )。
fit-content 自動調整空間 ( 類似 auto ),使其介在 min-width 和 max-width 之間。

下方範例呈現三種不同屬性值的效果,可以看出如果設定了 max-content,文字就不會換行 ( 換行不符合內容最大寬度 ),導致文字凸出原本的範圍,如果設定 min-content,則會根據內容最長的單字 ( 不會自動換行的字 ) 作為寬度,而 fit-content 的效果就跟原本預設值相同。

線上展示:https://codepen.io/oxxo/pen/RwzBNLM

<!-- HTML 程式碼 -->
<main>
  <div>STEAM 教育學習網秉持著 STEAM/STEM 的精神,透過一系列免費且高品質的教學與範例,讓所有人都能輕鬆跨入 STEAM 的學習領域。</div>
  <div class="a">STEAM 教育學習網秉持著 STEAM/STEM 的精神,透過一系列免費且高品質的教學與範例,讓所有人都能輕鬆跨入 STEAM 的學習領域。</div>
  <div class="b">STEAM 教育學習網秉持著 STEAM/STEM 的精神,透過一系列免費且高品質的教學與範例,讓所有人都能輕鬆跨入 STEAM 的學習領域。</div>
  <div class="c">STEAM 教育學習網秉持著 STEAM/STEM 的精神,透過一系列免費且高品質的教學與範例,讓所有人都能輕鬆跨入 STEAM 的學習領域。</div>
</main>


<!-- CSS 程式碼 -->
<style>
  main {
    width: 360px;
    border: 1px solid #000;
  }
  div {
    border: 1px solid #000;
    padding: 5px;
    margin: 10px;
    background: #ddd;
  }
  .a {width: max-content;}
  .b {width: min-content;}
  .c {width: fit-content;}
</style>

CSS 教學 - 寬度、高度和 box-sizing - 使用 max-width、min-width、fit-content 屬性值

box-sizing 定義寬高顯示方式

box-sizing 樣式屬性主要定義容器「寬度和高度的顯示方式」,有兩個屬性值:

屬性值 說明
content-box 預設值,寬高尺寸「不包含」內邊距與邊框寬度。
border-box 寬高尺寸「包含」內邊距和邊框寬度。

下方的範例使用不同的 box-sizing 屬性值,可以看出雖然寬高設定相同,但實際呈現的大小卻不同,class 為 b 的 div 因為設定了 box-sizing: border-box;,所以寬度和高度都包含了 paddingborder 的寬度。

線上展示:https://codepen.io/oxxo/pen/xxNzWGY

<!-- HTML 程式碼 -->
<div class="a"><span>oxxo<br/>( content-box )</span></div>
<div class="b"><span>apple<br/>( border-box )</span></div>

<!-- CSS 程式碼 -->
<style>
  div {
    width:150px;
    height:150px;
    border: 10px solid #000;
    margin: 10px;
    padding: 30px;
    float: left;      /* 靠左浮動排列 */
  }
  div span {
    background: yellow;
    padding: 0;
    margin: 0;
    border: none;
  }
  .a span {
    display: block;   /* .a 裡的 span 的顯示類型為 block */
    width: 150px;
    height: 150px;
  }
  .b {
    box-sizing: border-box;   /* .b 設定為 border-box */
  }
</style>

CSS 教學 - 寬度、高度 - box-sizing 定義寬高顯示方式

aspect-ratio 根據比例調整寬高

aspect-ratio 樣式屬性可以讓容器「根據指定的比例改變寬高」,沒有繼承特性,過去在動態調整寬高時,往往會借助百分比、CSS 的 calc() 函式搭配單位計算,甚至還得透過 JavaScript 動態計算,但自從 CSS 推出 aspect-ratio 樣式屬性後,單純透過 CSS 就可以根據比例調整寬高,是個十分方便的樣式屬性,屬性值有下列幾種寫法:

屬性值 說明
auto 預設值,使用容器原本的長寬比。
ratio 長寬比,寫法為 1/1、4/3、16/9...等。
auto ratio 如果容器已有長寬 ( 例如圖片 ) 則用 auto,否則使用長寬比。

下方範例使用五個不設定寬度的 div ( 寬度自動適應外圍 main 元素 ),透過 aspect-ratio 根據比例產生對應高度,搭配 CSS 動畫效果,就能看出當父元素寬度發生變化時,內容也會根據比例呈現出對應的長寬比。

線上展示:https://codepen.io/oxxo/pen/MYgoojp

<!-- HTML 程式碼 -->
<main>
  <div class="a">1:1</div>
  <div class="b">4:3</div>
  <div class="c">2:1</div>
  <div class="d">16:9</div>
  <div class="e">3:4</div>
</main>

<!-- CSS 程式碼 -->
<style>
  main {
    width: 100px;
    animation: oxxo 2s infinite alternate;
  }
  div {
    border: 1px solid #000;
    margin: 10px;
  }
  .a {aspect-ratio: 1/1;}
  .b {aspect-ratio: 4/3;}
  .c {aspect-ratio: 2/1;}
  .d {aspect-ratio: 16/9;}
  .e {aspect-ratio: 3/4;}
  @keyframes oxxo {
    from {width: 100px;}
    to {width: 150px;}
  }
</style>

CSS 教學 - 寬度、高度 - aspect-ratio 根據指定的比例改變寬高

小結

元素的寬度和高度雖然簡單,但卻會根據元素顯示類型的不同,出現細微的差異,雖然大部分的狀況都不會影響排版,但如果能深入瞭解寬高的定義,就可以讓元素更符合排版需求,做出更理想的網頁。

意見回饋

如果有任何建議或問題,可傳送「意見表單」給我,謝謝~

CSS 教學

基本介紹

認識 CSS 開始使用 CSS CSS 語法規則 CSS 命名原則 CSS 常用樣式屬性

CSS 選擇器

認識 CSS 選擇器 優先順序 ( 權重 ) 樣式繼承與聯集 使用巢狀結構語法 元素選擇器 ID 和 Class 選擇器 屬性選擇器 文件結構選擇器 虛擬類別選擇器 ( 結構 ) 虛擬類別選擇器 ( 類型 ) 虛擬類別選擇器 ( 輸入 ) 虛擬類別選擇器 ( 行為 ) 虛擬類別選擇器 ( 超連結 ) 虛擬類別選擇器 ( 邏輯 ) 虛擬類別選擇器 ( 其他 ) 虛擬元素選擇器 群組與組合選擇器

數值與單位

關鍵字與文字數值 長度與角度單位 位置名稱與時間單位

規則與定義

變數 ( Variables ) 媒體查詢 ( @media ) 容器查詢 ( @container ) 自訂屬性值 ( @property ) 匯入樣式 ( @import ) 分層優先順序 ( @layer )

函式類型

數學計算 文字與清單計數 形狀與線段 路徑 ( path ) 生成內容與引號

顏色與濾鏡

顏色單位 色彩模型 漸層色 影像濾鏡 ( filter ) 背景濾鏡 ( backdrop-filter ) 混合模式 ( mix-blend-mode )

文字與段落

設定字型 ( font-family ) 使用外部字型 定義字型 ( @font-face ) 文字尺寸 文字樣式 ( 常用 ) 文字樣式 ( 其他實用 ) 文字樣式 ( 特殊用途 ) 文字換行 文字空白與 Tab 大小 文字行高與縮排 文字水平與垂直對齊 文字書寫方向 文字自動分欄

元素容器

容器顯示類型 ( display ) 元素 display 對照表 盒子模型 ( Box Model ) 寬度與高度 內邊距 ( padding ) 外邊界 ( margin ) 邊框 ( border ) 邊框圓角 ( border-radius ) 影像邊框 ( border-image ) 輪廓 ( outline ) 內容溢出與裁切 ( overflow ) 內容範圍 ( contain ) 可見性與透明度

背景與陰影

背景顏色 背景圖 ( 定位、尺寸 ) 背景圖 ( 固定、重複 ) 背景圖 ( 多重背景、混合 ) 背景縮寫 ( background ) 容器陰影 ( box-shadow )

清單與表格

清單樣式 清單計數器 定義計數規則 表格基本樣式 表格邊框樣式 表格內容寬度與對齊

基本排版與定位

元素排版方式 浮動 ( float ) 浮動形狀 定位 ( position )

Flexbox 彈性排版

Flexbox 彈性盒子 Flexbox 對齊方式 Flexbox 彈性伸縮

Grid 網格排版

Grid 網格容器與格線 Grid 網格空間與命名 Grid 網格流向與間距 Grid 排列網格項目 Grid 項目對齊與順序

轉場與動畫

轉場 ( transition ) 轉場觸發事件 動畫 ( animation ) 自訂動畫路徑 ( offset ) 動畫觸發事件 多重動畫的權重與順序

變形、裁切與遮罩

裁切路徑 ( clip-path ) 影像遮罩 ( mask ) 物件填滿方式與定位 轉換函式 ( transform ) 平移、旋轉與縮放 3D 轉換與透視 3D 正多面體

視窗與使用者行為

捲軸樣式 ( scrollbar ) 滑鼠游標圖示 ( cursor ) 滑鼠事件 ( pointer-events ) 使用者選取 ( user-select ) 捲動行為 ( scroll、overscroll )

範例效果

CSS 圓餅圖 CSS 跑馬燈 Google 載入動畫 漸層色的轉場與動畫 電子時鐘數字 不規則形狀動畫