在css中可以使用計數器函數counter()和counters()來配合content屬性來分別實現給元素自動巢狀編號的效果,下面我們就來看看CSS計數器函數counter()和counters()是如何自動嵌套編號的。
css計數器使用多個counter()函數巢狀編號
css計數器的counter( )函數是設定元素單一編號的,但我們可以巢狀使用counter()函數來設定巢狀編號。
我們來看看是如何實現的,給html代碼:
<article> <h1>CSS计数器自动嵌套编号</h1> <h2>大标题</h2> <h3>二级标题</h3> <p> 二级标题的内容,二级标题的内容,二级标题的内容! </p> <h2>大标题</h2> <h3>二级标题</h3> <p> 二级标题的内容,二级标题的内容,二级标题的内容! </p> <h3>二级标题</h3> <p> 二级标题的内容,二级标题的内容,二级标题的内容! </p> </article>
效果圖:
##下面我們就來看看css是如何實現嵌套編號的。1、使用css計數器讓大標題
article { counter-reset: my-counter; } h2 { counter-increment: my-counter; } h2:before { content: counter(my-counter) ". "; }
2、使用css計數器讓二級標題
#在h3標籤的父容器h2標籤中為css計數器添加名稱“sub-counter”,初始化計數器;
然後在h3標籤中定義計數器每次遞增的值,在定義二級標題的樣式。
最後使用:before選擇器和content屬性把編號加到h3標籤前顯示。
h2 { counter-reset: sub-counter; } h3 { counter-increment: sub-counter; font-style: italic; color: #3498DB; } h3:before { content: counter(my-counter) "." counter(sub-counter) " "; }
使用counter(my-counter) 把大標題的編號放在最前面,在使用"."分隔,然後是使用counter(sub-counter)顯示二級標題自身的編號。
效果圖:
<div class="container"> <ul> <li> Item <ul> <li>Sub-Item</li> <li>Sub-Item <ul> <li>Sub-Sub-Item</li> <li>Sub-Sub-Item</li> </ul> </li> </ul> </li> <li> Item <ul> <li>Sub-Item</li> <li>Sub-Item</li> <li>Sub-Item</li> </ul> </li> </ul> </div>
.container { margin: 40px auto; max-width: 700px; background-color: white; padding: 1.5em; } ul { list-style: none; counter-reset: nested-counter;/*初始化css计数器*/ } ul li { counter-increment: nested-counter;/*定义css计数器每次递增的值*/ line-height: 1.6; } ul li:before { content: counters(nested-counter, ".") ") ";/*显示编号*/ font-weight: bold; }
以上是css計數器如何實現自動巢狀編號的詳細內容。更多資訊請關注PHP中文網其他相關文章!