搜尋

背景圖片 ( 重複、固定 )

這篇教學會介紹 CSS 背景圖片相關的樣式屬性,會運用 background-repeat 設定背景圖片的重複,也會使用 backgroud-attachment 設定背景圖是否固定在網頁中,當捲動網頁時背景圖固定不動。

快速導覽:

CSS 教學 - 背景圖片 ( 重複、固定 )

background-repeat 背景圖片重複

background-repeat 可以設定「背景圖是否重複」,沒有繼承特性,具有下列幾個屬性值:

屬性值 說明
repeat ( 預設值 ) 使用背景圖所設定的尺寸連續並重複出現,超過範圍的背景圖會被裁切。
no-repeat 不重複,呈現單一張背景圖。
space 使用空白分隔重複的背景圖,保持原本長寬尺寸重複且不被裁切。
round 修改重複的背景圖的長寬比例,讓重複的背景圖不被裁切。
repeat-x 等同 repeat 但只在水平方向重複。
repeat-y 等同 repeat 但只在垂直方向重複。

下列使用幾個 div 呈現不同的 background-repeat 屬性值效果。

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

<!-- 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 {
    height: 120px;
    width: 160px;
    margin: 10px;
    border: 1px solid #000;
    background-image: url("https://steam.oxxostudio.tw/download/css/border-img-2.jpg");
    background-size: 50px;
  }
  .a {background-repeat: repeat;}    /* 按照圖片設定尺寸重複 */
  .b {background-repeat: no-repeat;} /* 不重複 */
  .c {background-repeat: space;}     /* 使用空白分隔重複的背景圖,保持原本長寬尺寸重複且不被裁切 */
  .d {background-repeat: round;}     /* 修改重複的背景圖的長寬比例,讓重複的背景圖不被裁切 */
  .e {background-repeat: repeat-x;}  /* 水平重複 */
  .f {background-repeat: repeat-y;}  /* 垂直重複 */
</style>

CSS 教學 - 背景圖片 ( 重複、固定 ) - background-repeat 背景圖片重複

background-repeat 除了使用「一個」屬性值,也可以使用「兩個」屬性值 ( 使用空白分隔 ),例如「repeat round,第一個屬性值表示水平方向的重複,第二個屬性值表示垂直方向重複,下方列出與一個屬性值的對照表。

一個屬性值 等同兩個屬性值
repeat repeat repeat
no-repeat no-repeat no-repeat
space space space
round round round
repeat-x repeat no-repeat
repeat-y no-repeat repeat

下方範例會運用兩個屬性值的方式,做出水平與垂直使用不同重複方式的效果

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

<!-- HTML 程式碼 -->
<div class="a"></div>
<div class="b"></div>
<div class="c"></div>

<!-- CSS 程式碼 -->
<style>
  div {
    height: 120px;
    width: 160px;
    margin: 10px;
    border: 1px solid #000;
    background-image: url("https://steam.oxxostudio.tw/download/css/border-img-2.jpg");
    background-size: 50px;
  }
  .a {background-repeat: repeat space;}  /* 水平 rpeat,垂直 space */
  .b {background-repeat: space round;}   /* 水平 space,垂直 round */
  .c {background-repeat: repeat round;}  /* 水平 rpeat,垂直 round */
</style>

CSS 教學 - 背景圖片 ( 重複、固定 ) - background-repeat 背景圖片重複 ( 兩個屬性值 )

background-attachment 背景圖片固定

background-attachment 可以設定背景圖片「是否跟隨視窗或元素內容而捲動」,沒有繼承特性,具有下列屬性值:

屬性值 元素內容捲動 視窗捲動 背景位置
scroll 固定 ( 預設值 ) 跟著捲動 ( 預設值 ) 相對元素
fixed 固定 固定 相對 body
local 跟著捲動 跟著捲動 相對元素

下方範例會使用三個 div,分別呈現不同的 background-attachment 效果,當中使用了 overflow: scroll; 樣式讓 main 和 div 在「內容超出範圍」時可以捲動,所以可以使用滑鼠分別捲動 main 和 div 元素,捲動時就能觀察背景固定或跟隨捲動的狀態,此外,設定 fixed 的 div,背景圖是根據 body 元素做定位。

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

<!-- HTML 程式碼 -->
<main>
  <div class="a">STEAM 教育學習網是一個針對 STEAM 教育所設立的網站,目標整合各種程式、科學、科技、工藝或設計相關的基礎知識。隨著資訊科技進步以及「後疫情」時代的來臨,「自學」的趨勢也日益盛行,透過這個網站,除了紀錄我自己的學習歷程,更可以將目前正夯的新知或技術,分享給所需要的大朋友小朋友,希望對於想要自學的學生、家長或老師有所幫助。</div>
  <div class="b">STEAM 教育學習網是一個針對 STEAM 教育所設立的網站,目標整合各種程式、科學、科技、工藝或設計相關的基礎知識。隨著資訊科技進步以及「後疫情」時代的來臨,「自學」的趨勢也日益盛行,透過這個網站,除了紀錄我自己的學習歷程,更可以將目前正夯的新知或技術,分享給所需要的大朋友小朋友,希望對於想要自學的學生、家長或老師有所幫助。</div>
  <div class="c">STEAM 教育學習網是一個針對 STEAM 教育所設立的網站,目標整合各種程式、科學、科技、工藝或設計相關的基礎知識。隨著資訊科技進步以及「後疫情」時代的來臨,「自學」的趨勢也日益盛行,透過這個網站,除了紀錄我自己的學習歷程,更可以將目前正夯的新知或技術,分享給所需要的大朋友小朋友,希望對於想要自學的學生、家長或老師有所幫助。</div>
</main>

<!-- CSS 程式碼 -->
<style>
  main {
    width: 430px;
    height: 200px;
    padding: 5px;
    border: 1px solid #000;
    overflow: scroll;  /* 設定內容超出範圍就捲動 */
    background: #fff9;
  }
  div {
    float: left;       /* 靠左浮動 */
    width: 120px;
    height: 300px;
    border: 1px solid #000;
    margin: 5px;
    padding: 5px;
    font-size: 14px;
    color: #fff;
    overflow: scroll;  /* 設定內容超出範圍就捲動 */
    background-image: url("https://steam.oxxostudio.tw/image/index-css.jpg");
  }
  .a {background-attachment: scroll;}
  .b {background-attachment: fixed;}
  .c {background-attachment: local;}
</style>

CSS 教學 - 背景圖片 ( 重複、固定 ) - background-attachment 背景圖片固定

小結

background-repeatbackgroud-attachment 都是網頁設計中常見的背景處理技巧,不論是個人網頁或是大型公司的網頁,都會充分運用這些樣式來讓背景圖更有特色。

意見回饋

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

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 載入動畫 漸層色的轉場與動畫 電子時鐘數字 不規則形狀動畫