前言
在CSS3之前,只有ul和ol等列表元素中存在计数器,其他元素很难通过CSS实现计数功能。而CSS3之后,通过新增的counter属性,可以实现任意元素的计数。
使用
以本博客的代码行计数功能为例,代码标签构成方式如下:
页面展示效果如下:
可以看出,<pre>
标签嵌套<span>
标签,<pre>
标签为整段代码,<span>
标签为单行代码,因此计数代码行数也就是对<span>
标签的计数。
在后台CSS中增加以下CSS代码:
pre { ... position: relative; counter-reset: step 0; } pre span:before { position: absolute; content: counter(step); counter-increment: step 1; color: black; border-right: solid 2px #eb7350; }
其中counter
、counter-reset
、counter-increment
是最主要的属性,counter
用于设置计数器的名称,counter-reset
写在父元素中用于限定计数范围并将计数器重置为初始值,counter-increment
则写到子元素中,每次出现子元素,对计数器进行累加。
注意,通过将display属性设置为none或者hidden而隐藏的子元素不参与计数,而通过visibility:hidden等方式隐藏的子元素仍然参与计数。
得到以下效果:
像代码中一样,counter经常和伪元素搭配使用,避免污染被计数的元素,例如复制代码时不会复制到行数。
后话
为了兼容这个代码行数计算功能,我把之前发的上百篇博客挨个整理了一下,提前近一个月完成了早期博客的基本重构(尤其是被垃圾评论们骚扰最多的命令行工具nircmd,当时都写的什么玩意儿,直接重新写了),也算是拔了一月份立下的一个flag,后面的详细优化就可以慢慢来了。
女人固然是脆弱的,
母亲却是坚强的。
——维克多·雨果
评论
he blog was how do i say it… relevant, finally something that helped me. Thanks
https://gullybet.life/
242577 242773I discovered your blog website website on google and appearance some of your early posts. Preserve up the wonderful operate. I just extra increase Feed to my MSN News Reader. Seeking for toward reading far a lot more by you later on! 959114
836018 325850Water-resistant our wales in advance of when numerous planking. The specific wales surely are a selection of heavy duty snowboards that this height ones would be exactly the same in principle as a new shell planking having said that with much far more height to assist you thrust outward inside the evening planking. planking 338590
406341 5321Maintain up the great function , I read couple of weblog posts on this internet site and I believe that your site is real fascinating and has bands of excellent info . 294487
My spouse and I absolutely love your blog and find almost all of your post’s to be just what I’m looking for. Would you offer guest writers to write content for you personally? I wouldn’t mind composing a post or elaborating on many of the subjects you write related to here. Again, awesome blog!
http://www.tlovertonet.com/
878231 597945I believe this web web site has got quite exceptional indited articles content material . 599385
184768 678666Nice weblog here! following reading, i decide to buy a sleeping bag ASAP 496963
374944 85169Every e-mail you send ought to have your signature with the link to your web website or weblog. That typically brings in some visitors. 91413
331552 371434informatii interesante si utile postate pe blogul dumneavoastra. dar ca si o paranteza , ce parere aveti de inchirierea apartamente vacanta ?. 216468
998064 916956I agree together with your points , fantastic post. 110183
581492 992107Spot on with this write-up, I really suppose this internet site needs much far more consideration. probably be once a lot more to learn way far more, thanks for that info. 378879
902843 944445Its rare knowledgeable folks within this topic, nevertheless, you appear like theres a lot more you are talking about! Thanks 633519
827394 683753As a result youll call for ultra powerful online enterprise tips to keep operating in getting into matters right your incredible web-based work. MLM 370586
834905 398530Extremely intriguing topic , thanks for putting up. 673449
952603 314110Thanks for the information. And a response from you. car dealers hips san jose 170223
750599 441134Very interesting subject , thanks for putting up. 28544