計數器可以說是content的重點, 因為此功能非常強大, 實用, 並且不具有可替代性, 甚至可以實現連JavaScript都不好實現的效果.
所謂css計數器效果, 就是使用CSS程式碼實現隨元素的數目增多, 數值也跟著變大的效果, 有點類似於<ol>, 但是比ol更靈活
CSS計數器有兩個屬性 (counter-reset 和 counter-increment) 和一個方法 (counter() / counters()), 下面以次講解:
1. counter-reset
屬性counter-reset顧名思義就是 計數器-重置 的意思, 其實主要作用就是給計數器起個名字, 如果可能, 順便告訴下從哪個數字開始計數, 預設是0, 注意預設是0, 而不是1, 在網上可能會看到有很多例子預設顯示的第一個數字都是1, 而不是0, 這是因為受到 counter-increment 的影響, 後面詳細講解
先看一個簡單的例子
<div>下面將出現的數字</div>
<div class="counter"></div>複製程式碼
.counter {
counter-reset: resetname 2;
font-size: 24px;
color: #f66;
}
.counter:before {
content: counter(resetname);
}複製程式碼
如果將conter-reset 後面的2去掉, 那下面出現的數字就是 0
counter-reset 的計數重置可以是複數, 如 -2, 也可以是小數, 如 2.99, 不過, IE和FireFox對此都不認識, 認為是不合法的數值, 會當做0來處理, 在Chrome下, 任何小數都是向下取整, 如 2.99 會當成 2 來處理.
你以為到此為止了? 當然不是! counter-reset還有一手, 就是多個計數器同時命名, 列如:
.counter {
counter-reset: first 2 second 3;
font-size: 24px;
color: #f66;
}
.counter:before {
content: counter(first);
}
.counter:after {
content: counter(second);
}複製程式碼
效果如下
另外, counter-reset 還可以設定為 none, 和inherit, 取消重置以及繼承重置.
2. counter-increment
屬性 counter-increment 顧名思義就是 計數器遞增的意思, 值為counter-reset的一個或者多個關鍵字, 後面可以跟數字, 表示每次計數的變化值, 如果省略則使用預設變化值 1
CSS計數器的技術有一套自己的規則, 我們稱之為 “普照規則”, 具體來講就是, 普照源 (counter-reset) 唯一, 每普照(counter-increment)一次, 普照源增加一次計數
於是就能解決上面所說的 “預設值0″的問題了, 通常我們在使用計數器的時候, 都會使用counter-increment , 這個肯定要用, 不然怎麼遞增呢.
.counter {
counter-reset: incerment 2;
counter-increment: incerment;
font-size: 24px;
color: #f66;
}
.counter:before {
content: counter(incerment);
}複製程式碼
這個普照元素也可以寫直接寫到為元素上, 效果和上面一樣, 也是遞增1, 如果父元素和子元素都寫了, 那麼父元素遞增一次, 子元素遞增一次, 最後的結果就是遞增兩次
正如之前提到的, 這個變化值不一定都是1, 可以靈活設定, 比如
counter-increment: incerment 2;複製程式碼
變化值也可以是負數, 比如
.counter {
counter-reset: incerment 5;
counter-increment: incerment -2;
font-size: 24px;
color: #f66;
}
.counter:before {
content: counter(incerment);
}複製程式碼
值也可以是none 和 inherit
3. counter()/counters()
這兩個是方法, 不是屬性, 類似於CSS3中的 calc(), 這裡的作用就是顯示計數, 不過名稱和用法有多個
比如上面用到的 counter(name), 就是顯示計數
還可以寫成 counter(name, style)
那麼這個style是什麼呢, 它支援的關鍵字就是 list-style-type 所支援的那些, 它的作用就是我們的遞增和遞減不一定都是數字, 也可以使英文字母或者別的
list-style-type:
disc | circle | square | decimal | decimal-leading-zero |
lower-roman | upper-roman | lower-greek | lower-latin | upper-latin |
armenian | georgian | none | inherit
.counter {
counter-reset: styleType 2;
font-size: 24px;
color: #f66;
}
.counter:before {
counter-increment: styleType;
content: counter(styleType, lower-roman);
}複製程式碼
counter 還支援級聯, 也就是說, 一個content 屬性可以有多個 counter() 方法
.counter {
counter-reset: cascaderOne 2 cascaderTwo 3;
font-size: 24px;
color: #f66;
}
.counter:before {
content: counter(cascaderOne) `A` counter(cascaderTwo);
white-space: pre;
}複製程式碼
下面介紹一下 counters() 方法, 看似只比counter多個 s , 但卻有著不同的意思, counters 幾乎可以說是巢狀計數器的代名詞.
我們平時寫的時候不可能都是1, 2, 3, …, 還有比如 1.1, 1.2, 1.3…等類似的序號, 前者就是counter()乾的事, 後者就是counters()乾的事
counters的基本用法
counters(name, string, style);複製程式碼
其中 string 引數是字串, 需要用引號包含, 是必須引數, 表示子序號的連線符, style還是和counter的第二個引數一樣
下面一個完整的demo:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>content</title>
<style type="text/css">
* {
margin: 0;
padding: 0;
}
ul, li {
list-style: none;
}
.reset {
padding-left: 20px;
counter-reset: fe;
}
.counter:before {
content: counters(fe, `.`) `. `;
counter-increment: fe;
}
</style>
</head>
<body>
<div class="reset">
<div class="counter">前端開發FE
<div class="reset">
<div class="counter">前端開發FE111</div>
<div class="counter">前端開發FE222
<div class="reset">
<div class="counter">前端開發FEsss</div>
<div class="counter">前端開發FE</div>
<div class="counter">前端開發FE</div>
</div>
</div>
<div class="counter">前端開發FE3333</div>
</div>
</div>
<div class="counter">後端開發</div>
<div class="counter">PM
<div class="reset">
<div class="counter">瞎提需求</div>
</div>
</div>
</div>
</body>
</html>複製程式碼
效果如下
參考連結