CSS 文字與清單計數 ( 函式類型 )
雖著 CSS 的版本演進,也陸續支援動態取得元素屬性等好用的功能,這篇教學會介紹「文字與清單計數」相關的 CSS 函式,例如 attr()、url()、counter()、counters() 等等,透過動態取得的文字或變數,讓版面的操控更具彈性。
「文字與清單計數」的 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 的前方和後方都加上對應屬性的文字。
<!-- 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>
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 會加入背景圖片,清單則會使用圖片作為清單標記。
<!-- 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>
url()
除了使用網址作為參數,也支援「base64 編碼」或「SVG 程式碼」的圖片內容,下方的範例執行後,會用這兩種方式呈現背景圖片。
<!-- 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>
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()
定義清單的數字標記格式。
<!-- 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>
counters()
「counters()
」是「多層計數器」CSS 函式,具有兩三個參數,分別是「計數器名稱」、「分隔符」以及「計數器類型」, 有別於 counter
只能取得「單層」的計數數值,counters()
使用後可以「保留父層數值,並結合新的計數器數值」,必須搭配清單的「counter-reset
」和「counter-increment
」樣式屬性使用,基本寫法如下:
li::marker {
content: counters(名稱, 分隔符, 類型);
}
li::before {
content: counters(名稱, 分隔符, 類型);
}
下方的範例執行後,會使用 counters()
定義清單的數字標記格式。
<!-- 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 函式已經存在許久,特別是 url()
,由於太常會用到,甚至會忘記了它也是一種 CSS 函式,此外,雖然目前 attr()
只能應用在基本虛擬元素,但隨著瀏覽器的進步,相信不久的將來就能真正發揮出它的功能囉。
意見回饋
如果有任何建議或問題,可傳送「意見表單」給我,謝謝~