css計數器效果是指使用CSS程式碼實現隨元素的數目增多, 數值也跟著變大的效果, 有點類似於
- , 但是比ol更靈活。
(推薦教學:css影片教學)
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>
相关推荐:CSS教程
以上是詳細介紹CSS計數器的詳細內容。更多資訊請關注PHP中文網其他相關文章!

在這篇文章中,布萊克·莫里(Blackle Mori)向您展示了一些駭客,同時試圖推動同位HTML支持的極限。如果您敢於使用這些,以免您也被標記為CSS罪犯。

具有CSS的自定義光標很棒,但是我們可以將JavaScript提升到一個新的水平。使用JavaScript,我們可以在光標狀態之間過渡,將動態文本放置在光標中,應用複雜的動畫並應用過濾器。

互動CSS動畫和元素相互啟動的元素在2025年似乎更合理。雖然不需要在CSS中實施乒乓球,但CSS的靈活性和力量的增加,可以懷疑Lee&Aver Lee有一天會成為一種

有關利用CSS背景濾波器屬性來樣式用戶界面的提示和技巧。您將學習如何在多個元素之間進行背景過濾器,並將它們與其他CSS圖形效果集成在一起以創建精心設計的設計。

好吧,事實證明,SVG的內置動畫功能從未按計劃進行棄用。當然,CSS和JavaScript具有承載負載的能力,但是很高興知道Smil並沒有像以前那樣死在水中

是的,讓#039;跳上文字包裝:Safari Technology Preview In Pretty Landing!但是請注意,它與在鉻瀏覽器中的工作方式不同。

此CSS-tricks更新了,重點介紹了年鑑,最近的播客出現,新的CSS計數器指南以及增加了幾位新作者,這些新作者貢獻了有價值的內容。

在大多數情況下,人們展示了@Apply的@Apply功能,其中包括Tailwind的單個property實用程序之一(會改變單個CSS聲明)。當以這種方式展示時,@Apply聽起來似乎很有希望。如此明顯


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

WebStorm Mac版
好用的JavaScript開發工具

Dreamweaver CS6
視覺化網頁開發工具