搜尋

CSS 文字與清單計數 ( 函式類型 )

雖著 CSS 的版本演進,也陸續支援動態取得元素屬性等好用的功能,這篇教學會介紹「文字與清單計數」相關的 CSS 函式,例如 attr()、url()、counter()、counters() 等等,透過動態取得的文字或變數,讓版面的操控更具彈性。

CSS 教學 - CSS 函式 ( 文字與清單 )

「文字與清單計數」的 CSS 函式

下方列出「文字與清單計數」類型的 CSS 函式 ( 目前所有瀏覽器都支援 ):

文字與清單函式 說明
attr() 取得套用該選擇器元素的屬性值。
url() 網址。
counter() 計數器。
counters() 多層計數器。

attr()

attr()」是「取得套用該選擇器元素的屬性值」CSS 函式,通常會搭配虛擬元素的 content 一同使用,基本寫法如下:

div::before {
  content: attr(name);  /* 讀取 name 屬性數值作為內容文字 */
}
div::after {
  content: "<< " attr(name) " >>";  /* 讀取 name 屬性數值作為內容文字,文字左右加上額外文字 */
}

雖然 W3C 所制定的 attr() 可以將讀取的數值應用於長度、角度、顏色等 CSS 樣式,但很可惜的是目前所有的瀏覽器都「不支援」,不然應該可以大幅減少程式碼,讓版面的設計更加靈活,例如目前並「不支援」下方的寫法:

div {
  width: attr(width px);              /* 讀取 width 屬性數值作為寬度,單位 px */
  background: attr(bg-color, "red");  /* 讀取 bg-color 屬性數值作為背景色,如果沒有就用 red */
}

下方的範例執行後,會使用虛擬元素,將 div 的前方和後方都加上對應屬性的文字。

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

<!-- HTML 程式碼 -->
<div left="123" right="456">oxxo</div>
<div left="789" right="000">apple</div>

<!-- CSS 程式碼 -->
<style>
  div {
    border: 1px solid #000;
    margin:10px;
    padding:10px;
  }

  div::before {
    content: attr(left) ", ";
  }

  div::after {
    content: " ," attr(right);
  }
</style>

CSS 教學 - CSS 函式 ( 文字與清單 ) - attr()

url()

url()」是「網址」CSS 函式,通常應用於「背景圖片、清單圖示、滑鼠游標、外部字體」等需要使用 url 的樣式,使用方法如下:

div {
  background-image: url("oxxo.gif");
  list-style-image: url("../icon/icon-01.jpg");
  content: url("bg.jpg");
  cursor: url("mycursor.cur");
  src: url("google-font.woff");
}
div::before {
  content: " - " url(star.gif);
}

url() 的網址可以「使用引號」或使用「雙引號」或「單引號」包覆,如果網址中有出現「括號、空格或引號」,則必須使用引號包覆,例如下方的寫法都可以正常運作的。

background-image: url(oxxo.gif);   /* 不使用引號 */
background-image: url('oxxo.gif'); /* 使用單引號 */
background-image: url("oxxo.gif"); /* 使用雙引號 */

下方的範例執行後,畫面中的 div 會加入背景圖片,清單則會使用圖片作為清單標記。

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

<!-- HTML 程式碼 -->
<div></div>
<ul>
  <li>oxxo</li>
  <li>banana</li>
  <li>orange</li>
  <li>papaya</li>
</ul>

<!-- CSS 程式碼 -->
<style>
  div {
    width: 300px;
    height: 200px;
    background-image: url(https://img.freepik.com/free-vector/minimal-geometric-stripe-shape-background_1409-1014.jpg);
  }
  li {
    list-style: url(https://cdn-icons-png.freepik.com/16/11694/11694600.png);
  }
</style>

CSS 教學 - CSS 函式 ( 文字與清單 ) - url()

url() 除了使用網址作為參數,也支援「base64 編碼」或「SVG 程式碼」的圖片內容,下方的範例執行後,會用這兩種方式呈現背景圖片。

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

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

<!-- CSS 程式碼 -->
<style>
  div {
    width: 225px;
    height: 225px;
    border: 1px solid black;
    margin: 5px;
  }
  .a {
    background-image: url()
  }
  .b {
    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="%23fffefd" d="M -0.5,-0.5 C 74.5,-0.5 149.5,-0.5 224.5,-0.5C 224.5,74.5 224.5,149.5 224.5,224.5C 149.5,224.5 74.5,224.5 -0.5,224.5C -0.5,149.5 -0.5,74.5 -0.5,-0.5 Z"/></g><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>

CSS 教學 - CSS 函式 ( 文字與清單 ) - url() 使用編碼呈現圖片

counter()

counter()」是「計數器」CSS 函式, 具有兩個參數,分別是「計數器名稱」以及「計數器類型」,使用後可以「產生指定格式的計數器數值」,必須搭配清單的「counter-reset」和「counter-increment」樣式屬性使用,基本寫法如下:

li::marker { 
  content: counter(名稱, 類型);
}
li::before { 
  content: counter(名稱, 類型);
}

常用的計數器類型如下表所示:

類型 說明
decimal 阿拉伯數字
decimal-leading-zero 個位數開頭補零阿拉伯數字
lower-alpha 小寫英文字母
lower-greek 小寫希臘字母
lower-roman 小寫羅馬數字
upper-alpha 大寫英文字母
upper-greek 大寫希臘字母
upper-roman 大寫羅馬數字
cjk-ideographic 中文數字
hiragana 日文平假名
katakana 日文片假名
armenian 希臘數字
georgian 喬治亞文
hebrew 希伯來文

下方的範例執行後,會使用 counter() 定義清單的數字標記格式。

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

<!-- HTML 程式碼 -->
<ul>
  <li>oxxo</li>
  <li>banana</li>
  <li>apple
    <ul>
      <li>aaa
        <ul>
          <li>xxx</li>
          <li>yyy</li>
          <li>yyy</li>
        </ul>
      </li>
      <li>bbb</li>
      <li>ccc</li>
    </ul>
  </li>
  <li>orange</li>
</ul>

<!-- CSS 程式碼 -->
<style>
ul {
  counter-reset: oxxo;
  list-style-type: none;
}
li{
  counter-increment: oxxo;
}
li::before {
  content: counter(oxxo, decimal) ' > ';
}
</style>

CSS 教學 - CSS 函式 ( 文字與清單 ) - counter()

counters()

counters()」是「多層計數器」CSS 函式,具有兩三個參數,分別是「計數器名稱」、「分隔符」以及「計數器類型」, 有別於 counter 只能取得「單層」的計數數值,counters() 使用後可以「保留父層數值,並結合新的計數器數值」,必須搭配清單的「counter-reset」和「counter-increment」樣式屬性使用,基本寫法如下:

li::marker { 
  content: counters(名稱, 分隔符, 類型);
}
li::before { 
  content: counters(名稱, 分隔符, 類型);
}

下方的範例執行後,會使用 counters() 定義清單的數字標記格式。

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

<!-- HTML 程式碼 -->
<ul>
  <li>oxxo</li>
  <li>banana</li>
  <li>apple
    <ul>
      <li>aaa
        <ul>
          <li>xxx</li>
          <li>yyy</li>
          <li>yyy</li>
        </ul>
      </li>
      <li>bbb</li>
      <li>ccc</li>
    </ul>
  </li>
  <li>orange</li>
</ul>

<!-- CSS 程式碼 -->
<style>
  ul {
    counter-reset: oxxo;
    list-style-type: none;
  }
  li{
    counter-increment: oxxo;
  }
  li::before {
    content: counters(oxxo, '-', decimal) '、';
  }
</style>

CSS 教學 - CSS 函式 ( 文字與清單計數 ) - counters()

小結

「文字與清單計數」相關的 CSS 函式已經存在許久,特別是 url(),由於太常會用到,甚至會忘記了它也是一種 CSS 函式,此外,雖然目前 attr() 只能應用在基本虛擬元素,但隨著瀏覽器的進步,相信不久的將來就能真正發揮出它的功能囉。

意見回饋

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

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