背景圖片 ( 定位、定位點、尺寸 )
CSS 除了可以設定背景顏色,還可以設定「背景圖片」,這篇教學會介紹 CSS 設定背景圖片的樣式屬性:background-image、background-position、background-size、background-origin,實作背景圖片的定位、定位點以及尺寸設定。
快速導覽:
background-image 背景圖片
background-image
表示元素的「背景圖片」,有下列幾個特性:
- 支援使用「
url()
函式」讀取圖檔,包含外部圖檔、base64 點陣圖或 SVG 內嵌影像等。- 支援使用「漸層」相關函式使用漸層色 ( 參考「CSS 函式 ( 漸層色 )」 )
- 預設背景圖會延伸至「容器 padding 區域 ( 不會延伸到邊框 )」。
- 在顯示階層中,
background-image
會覆蓋background-color
。- 不會繼承。
下方的範例會讓不同的元素呈現不同的背景圖片,在預設狀態下背景圖片會延伸填滿 padding
空間,從中也可以觀察到透明背景的圖片,會顯示下方 background-color
的色彩。
<!-- HTML 程式碼 -->
<div class="a">使用 jpg</div>
<div class="b">使用背景透明 png</div>
<div class="c">使用 base64 圖檔</div>
<div class="d">使用內嵌 SVG</div>
<!-- CSS 程式碼 -->
<style>
div {
width: 200px;
height: 150px;
border: 1px solid #000;
background-color: yellow;
margin: 5px;
float: left;
}
.a {
color: white;
background-image: url("https://steam.oxxostudio.tw/image/index-css.jpg");
}
.b {
background-image: url("https://steam.oxxostudio.tw/download/css/function-filter-demo.png");
}
.c {
background-image: url("");
}
.d {
background-image: url('data:image/svg+xml,<%3Fxml version="1.0" encoding="UTF-8"%3F><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="225px" height="225px" style="shape-rendering:geometricPrecision; text-rendering:geometricPrecision; image-rendering:optimizeQuality; fill-rule:evenodd; clip-rule:evenodd" xmlns:xlink="http://www.w3.org/1999/xlink"><g><path style="opacity:1" fill="%23ff5916" d="M 67.5,170.5 C 65.9814,173.526 65.3148,176.859 65.5,180.5C 65.5034,183.025 65.8367,185.359 66.5,187.5C 67.6737,196.514 71.507,204.181 78,210.5C 78.6877,211.332 78.521,211.998 77.5,212.5C 48.2324,195.34 32.0657,169.674 29,135.5C 27.6436,114.26 31.9769,94.26 42,75.5C 42.6667,74.1667 43.3333,74.1667 44,75.5C 46.6601,86.484 52.1601,95.8173 60.5,103.5C 60.56,104.043 60.8933,104.376 61.5,104.5C 61.8333,103.667 62.1667,102.833 62.5,102C 62.0542,98.6499 61.3875,95.4833 60.5,92.5C 60.2665,87.1053 60.5998,81.772 61.5,76.5C 62.4915,71.9496 63.4915,67.2829 64.5,62.5C 74.5133,33.6547 94.1799,14.8213 123.5,6C 124.833,5.33333 126.167,5.33333 127.5,6C 125.539,9.21483 124.373,12.7148 124,16.5C 123.298,25.2032 123.632,33.8698 125,42.5C 128.058,50.2834 131.392,57.9501 135,65.5C 143.853,79.8737 152.187,94.5404 160,109.5C 161.897,115.485 163.73,121.485 165.5,127.5C 177.98,110.853 182.48,92.1865 179,71.5C 200.654,107.867 200.988,144.534 180,181.5C 168.36,199.822 152.194,211.989 131.5,218C 153.158,203.498 160.325,183.665 153,158.5C 150.433,164.069 147.433,169.403 144,174.5C 142.104,176.53 139.937,178.197 137.5,179.5C 137.158,172.876 135.658,166.543 133,160.5C 124.602,147.036 117.269,133.036 111,118.5C 109.524,113.594 108.524,108.594 108,103.5C 92.0711,117.283 86.0711,134.617 90,155.5C 91.8739,162.952 94.0405,170.285 96.5,177.5C 84.6868,173.684 77.3534,165.684 74.5,153.5C 70.7749,158.614 68.4415,164.281 67.5,170.5 Z"/></g><g><path style="opacity:1" fill="%23ff8e66" d="M 64.5,62.5 C 63.4915,67.2829 62.4915,71.9496 61.5,76.5C 61.0439,71.4045 62.0439,66.7378 64.5,62.5 Z"/></g><g><path style="opacity:1" fill="%23ffcbb9" d="M 60.5,92.5 C 61.3875,95.4833 62.0542,98.6499 62.5,102C 62.1667,102.833 61.8333,103.667 61.5,104.5C 60.8933,104.376 60.56,104.043 60.5,103.5C 60.7037,100.082 60.7037,96.4158 60.5,92.5 Z"/></g><g><path style="opacity:1" fill="%23ff895f" d="M 67.5,170.5 C 66.7081,176.13 66.3748,181.797 66.5,187.5C 65.8367,185.359 65.5034,183.025 65.5,180.5C 65.3148,176.859 65.9814,173.526 67.5,170.5 Z"/></g></svg>');
}
</style>
background-image
如果搭配「漸層色」相關函式,就能讓元素背景顯示漸層色,下方會使用六個不同的 div 顯示六種不同的漸層色 ( 參考「CSS 函式 ( 漸層色 )」)。
<!-- HTML 程式碼 -->
<div class="a"></div>
<div class="b"></div>
<div class="c"></div>
<div class="d"></div>
<div class="e"></div>
<div class="f"></div>
<!-- CSS 程式碼 -->
<style>
div {
width: 150px;
height: 150px;
border: 1px solid #000;
background-color: yellow;
margin: 2px;
float: left;
}
.a {
color: white;
background-image: linear-gradient(to top, red, yellow);
}
.b {
background-image: radial-gradient(red, orange, yellow, green, blue, purple);
}
.c {
background-image: conic-gradient(red, orange, yellow, green, blue, purple, red);
}
.d {
background-image: repeating-linear-gradient(
45deg,
orange 0%, orange 10%,
black 10%, black 20%);
}
.e {
background-image: repeating-radial-gradient(at 70% 70%, orange 0%, black 20%);
}
.f {
background: repeating-conic-gradient(
red 0deg, red 20deg,
white 20deg, white 40deg
);
}
</style>
如果將背景圖片套用到「不可置換行內元素」,因為實際的「內容區域」仍然存在 padding
和 border
的空間,因此套用背景圖片時,預設狀態下背景圖片仍然會填滿這些空間,此外,由於透過「行高」所產生的空間不屬於內容區域,就不會填滿背景圖片。
<!-- HTML 程式碼 -->
<div class="a">
<span>STEAM 教育學習網透過一系列<strong>免費且高品質</strong>的教學與範例,讓所有人都能輕鬆跨入 STEAM 的學習領域。</span>
</div>
<div class="b">
<span>STEAM 教育學習網透過一系列<strong>免費且高品質</strong>的教學與範例,讓所有人都能輕鬆跨入 STEAM 的學習領域。</span>
</div>
<!-- CSS 程式碼 -->
<style>
div {
width: 240px;
margin: 20px;
padding: 10px;
font-size: 14px;
border: 1px solid #000;
}
strong {background-image: url("https://steam.oxxostudio.tw/download/css/border-img-2.jpg");}
.a strong {
padding:20px;
border: 10px solid #f005; /* 利用 padding 和 border 延伸範圍 */
}
.b {line-height: 50px;} /* 利用行高產生空間 */
</style>
如果是圖片元素 img 或 svg 等「可置換」行內容器 ( 顯示類型大多都是 inline-block
),在預設狀態下 padding
和 border
會向外擴展範圍,背景色圖片也就會填滿這些範圍,如果圖片本身是透明背景,透明區域也會顯示背景圖片。
<!-- HTML 程式碼 -->
<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/border-svg-2.svg">
<!-- CSS 程式碼 -->
<style>
img {
width: 120px;
background-image: url("https://steam.oxxostudio.tw/download/css/border-img-2.jpg");
}
.a {
border: 10px solid #000;
padding: 10px;
}
.b {
border: 20px dashed #00f8;
padding: 5px;
}
.c {
border: 5px double #000;
padding: 5px;
}
</style>
background-position 背景圖片定位
background-position
使用「對齊關鍵字」或「位置偏移量」來定義背景圖片的位置,可以將關鍵字與偏移量互相搭配,產生「1~4」個屬性值,沒有繼承特性,下列方列出相關撰寫語法:
background-position
衍伸的樣式屬性為background-position-x
和background-position-y
,分別只針對水平方向和垂直方向的背景定位。
對齊關鍵字
單純使用位置名稱進行對齊,這個寫法會有「1~2」個屬性值,使用後表示會將背景圖片的邊緣或中心點貼齊指定位置,注意,不能同時使用「top 與 bottom」或「left 與 right」。
關鍵字 等同屬性值 說明 top center top
靠上對齊 right right center
靠右對齊 bottom center bottom
靠下對齊 left left center
靠左對齊 center center center
置中對齊 left top - 靠左上對齊 ( 預設值 ) left bottom - 靠左下對齊 right top - 靠右上對齊 right bottom - 靠右下對齊 位置偏移量 ( 百分比 )
使用百分比單位,在沒有設定對齊關鍵字的狀態下,採用「
left top
」的方式進行偏移,並按照「百分比公式」計算偏移量,由於最終偏移結果是按照公式計算出的數值,如果背景圖尺寸大於元素尺寸,計算後會往反向移動 ( 類似設定負值的 px ),如果背景圖尺寸小於元素尺寸,計算後會順向移動,這個寫法會有「1~2」個屬性值。( 容器寬度 - 圖片寬度 ) * x 偏移百分比 = x 方向偏移量 ( 容器高度 - 圖片高度 ) * y 偏移百分比 = y 方向偏移量
屬性值 等同屬性值 ( top left ) 說明 50%
50% 50%
左往右偏移 50%,上往下偏移 50% 50% 100%
- 左往右偏移 50%,上往下偏移 100% 位置偏移量 ( px、em、rem )
使用非百分比的長度單位,在沒有設定對齊關鍵字的狀態下,採用「
left top
」的方式進行偏移,px 表示像素,em 表示元素本身字型大小,rem 表示根元素字型大小,設定負值會往反方向移動,這個寫法會有「1~2」個屬性值。屬性值 等同屬性值 ( top left ) 說明 50px
50px 50px
左往右偏移 50px,上往下偏移 50px 50px 100px
- 左往右偏移 50px,上往下偏移 100px 混合對齊關鍵字與位置偏移量
將「對齊關鍵字」和「位置偏移量」組合,就能指定「哪個方向的偏移量」,注意,使用 center 位置關鍵字不會進行偏移,這個寫法會有「2~4」個屬性值。
屬性值 等同屬性值 說明 left 50px
left 50px center
左往右偏移 50px,垂直置中 bottom 100px
center bottom 100px
水平置中,下往上偏移 100px 50px bottom 100px
left 50px bottom 100px
左往右偏移 50px,下往上偏移 100px 50px top
left 50px top
左往右偏移 50px,靠上對齊 right 20% bottom 20%
- 右往左偏移 20%,下往上偏移 20%
下方範例使會使用幾個 div,分別呈現不同定位的效果 ( 背景圖使用 1~9 的九宮格圖片 )。
<!-- HTML 程式碼 -->
<div class="a"></div>
<div class="b"></div>
<div class="c"></div>
<div class="d"></div>
<div class="e"></div>
<div class="f"></div>
<!-- CSS 程式碼 -->
<style>
div {
width: 100px;
height: 100px;
border: 1px solid #000;
margin: 10px;
background-image: url("https://steam.oxxostudio.tw/download/css/border-img-2.jpg");
}
.a {background-position: center center;} /* 水平置中,垂直置中 */
.b {background-position: 0% 0%;} /* 靠左靠上對齊,偏移 0% */
.c {background-position: right bottom;} /* 靠右靠下對齊 */
.d {background-position: 20px 50px;} /* 靠左靠上對齊,往右移動 20px,往下移動 50px */
.e {background-position: right 20px bottom 50px;} /* 靠右靠下對齊,往左移動 20px,往上移動 50px */
.f {background-position: center bottom 20px;} /* 水平置中,靠下對齊,往上移動 20px */
</style>
background-origin 背景圖片定位參考
由於網頁每個元素都是「容器」,容器會按照「容器盒子模型」分成內邊距、邊框和外邊界,因此需要依靠 CSS 的 background-origin
樣式屬性,設定背景圖片的定位點,這也是背景圖片定位的參考依據,background-origin
有下列的屬性值:
屬性值 | 說明 |
---|---|
border-box | 對齊點為邊框 ( border ) 外緣。 |
padding-box | 對齊點為內邊距 ( padding ) 外緣。 |
content-box | 對齊點為內容外緣。 |
下方的範例會設定背景不要重複,並使用黃色背景色觀察不同屬性值的效果,從中可以觀察如果沒有從邊框或內邊距進行定位對齊的背景圖,邊框或內邊距就會顯示背景的黃色 ( 因為背景色會延伸至邊框外緣 )。
<!-- HTML 程式碼 -->
<div class="a"></div>
<div class="b"></div>
<div class="c"></div>
<!-- CSS 程式碼 -->
<style>
div {
width: 150px;
height: 50px;
border: 20px solid #0005;
padding: 20px;
margin: 10px;
background: no-repeat; /* 背景不重複 */
background: cover;
background-image: url("https://steam.oxxostudio.tw/download/css/border-img-2.jpg");
background-color: yellow; /* 背景色黃色 */
}
.a {background-origin: border-box;} /* 背景圖的定位從邊框外緣開始 */
.b {background-origin: padding-box;} /* 背景圖的定位從內邊距外緣開始 */
.c {background-origin: content-box;} /* 背景圖的定位從內容外緣開始 */
</style>
如果將背景圖改成「漸層色」,也會遵循背景圖定位點的設定 ( 漸層樣式:background-image: linear-gradient(to top, blue, yellow);
)。
不過如果有設定 background-clip
樣式屬性,則在特定屬性值的狀態下,背景會被「裁切」,不論是背景色或是背景圖都不會出現 ( 參考:background-clip 裁切背景 ),下方的範例設定 background-clip: content-box;
,因此只有內容會顯示背景圖,但背景圖仍然會按照 background-origin
而設定定位點。
<!-- HTML 程式碼 -->
<div class="a"></div>
<div class="b"></div>
<div class="c"></div>
<!-- CSS 程式碼 -->
<style>
div {
width: 150px;
height: 50px;
border: 20px solid #0005;
padding: 20px;
margin: 10px;
background: no-repeat; /* 背景不重複 */
background: cover;
background-image: url("https://steam.oxxostudio.tw/download/css/border-img-2.jpg");
background-color: yellow; /* 背景色黃色 */
background-clip: content-box; /* 設定背景裁切模式 */
}
.a {background-origin: border-box;} /* 背景圖的定位從邊框外緣開始 */
.b {background-origin: padding-box;} /* 背景圖的定位從內邊距外緣開始 */
.c {background-origin: content-box;} /* 背景圖的定位從內容外緣開始 */
</style>
background-size 背景圖片尺寸
background-size
使用「尺寸關鍵字」或「尺寸數值」的屬性值來定義背景圖片的尺寸,沒有繼承特性,由於 background-size
主要針對「具有長寬尺寸或比例」的圖片計算出背景圖的長寬,因此如果使用的圖片沒有長寬尺寸或比例 ( 例如漸層色、部分特殊設定的 SVG ),就不會套用背景圖片尺寸樣式。
下方列出屬性值的說明:
屬性值 | 類型 | 說明 |
---|---|---|
cover | 關鍵字 | 維持圖片比例,將寬度或高度縮放至元素「最大邊長」( 無法和數值搭配 )。 |
contain | 關鍵字 | 維持圖片比例,將寬度或高度縮放至元素「最小邊長」」( 無法和數值搭配 )。 |
auto | 關鍵字 | 維持圖片比例,根據寬調整高,或根據高調整寬,沒有設定寬高就使用圖片原始尺寸。 |
N% | 數值 | 寬 = 元素寬 x N%,高 = 元素高 x N%。 |
X% Y% | 數值 | 寬 = 元素寬 x X%,高 = 元素高 x Y%。 |
Npx | 數值 | 寬 = Npx,高 = Npx。 |
Xpx Ypx | 像數值 | 寬 = Xpx,高 = Ypx。 |
em | 數值 | 使用元素字型大小,算法等同 px 或 % |
rem | 數值 | 使用根元素字型大小,算法等同 px 或 % |
使用 background-size
時,只有 auto 關鍵字可以和數值共同使用,產生 1~2 個屬性值,如果 auto 寫在數值左方表示寬度等比例調整,auto 寫在數值右方表示高度等比例調整,下方使用幾個 div,呈現不同的 background-size
屬性值的效果 ( 範例將背景圖片設定為不重複 )。
<!-- HTML 程式碼 -->
<div class="a"></div>
<div class="b"></div>
<div class="c"></div>
<div class="d"></div>
<div class="e"></div>
<div class="f"></div>
<!-- CSS 程式碼 -->
<style>
div {
width: 180px;
height: 100px;
border: 1px solid #000;
margin: 10px;
background-repeat: no-repeat;
background-image: url("https://steam.oxxostudio.tw/download/css/border-img-2.jpg");
}
.a {background-size: cover;} /* 填滿最大邊長 */
.b {background-size: contain;} /* 填滿最小邊長 */
.c {background-size: auto 40%;} /* 寬度等比例,高度 = 元素高 x 40% */
.d {background-size: 40%;} /* 寬度 = 元素寬 x 40%,高度 = 元素高 x 40% */
.e {background-size: 80% 20px;} /* 寬度 = 元素寬 x 80%,高度 = 20px */
.f {background-size: 30px 200px;} /* 寬度 = 30px,高度 = 200px */
</style>
小結
替元素套用背景圖的用法和使用 img 元素有點類似,但 CSS 提供了許多控制背景圖的樣式屬性,只要充分運用這些樣式,就能透過背景圖做出更多有趣的效果。
意見回饋
如果有任何建議或問題,可傳送「意見表單」給我,謝謝~