当前位置: 首页 > article >正文

CSS计数器

CSS 中的计数器类似于变量,可以实现简单的计数功能,并将结果显示在页面上,在早期的网站上应用比较广泛。要实现计数器需要用到以下几个属性:

  • counter-reset:创建或者重置计数器;
  • counter-increment:递增变量;
  • content:插入生成的内容;
  • counter() 或 counters():将计数器的值添加到元素。

下面我们就来看一下 CSS 中的计数器是如何使用的。

初始化计数器

要使用计数器首先需要使用 counter-reset 属性来创建一个计数器,这一过程便叫做初始化计数器。counter-reset 属性的语法格式如下:

counter-reset:none | [ ]

参数说明如下:

  • none:阻止计数器复位;
  • :定义计数器的名称;
  • :定义计数器的起始值,默认值为 0,可以为负值。

计数器自增

初始化计数器后,可以通过 counter-increment 属性来指定计数器何时自增,语法格式如下:

counter-increment:none | [ ]

参数说明如下:

  • none:阻止计数器增加;
  • :定义要自增的计数器名称;
  • :定义计数器每次增加的数值,默认值为 1,可以为负值。

显示计数器

最后,就是如何显示计数器了。要显示计数器您可以使用 counter() 或 counters() 函数,这两个函数的语法格式如下:

counter(name)
counters(name, string, list-style-type)

参数说明如下:

  • name:计数器的名称;
  • string:当计数器嵌套使用时,用来拼接的字符串;
  • list-style-type:计数器显示的风格,可以是 CSS 中允许的任何《list-style-type 属性》的值。

下面通过一个简单的示例来演示计数器的使用:

<!DOCTYPE html>

<html>

<head>

    <style>

        body {

            counter-reset: chapter; 

        }

        h5, h6 {

            margin: 5px 0 5px;

        }

        h5 {

            counter-reset: section;

            counter-increment: chapter;

        }

        h6 {

            counter-increment: section;

        }

        h5:before {

            content: "Chapter " counter(chapter) ". ";

        }

        h6:before {

            content: counter(chapter) "." counter(section) " ";

        }

    </style>

</head>

<body>

    <h5>程序设计语言</h5>

    <h6>HTML and CSS</h6>

    <h6>JavaScript</h6>

    <h6>PHP</h6>

    <h6>Java</h6>



    <h5>数据库管理系统</h5>

    <h6>MySQL</h6>

    <h6>MariaDB</h6>

    <h6>PostgreSQL</h6>

    <h6>Oracle</h6>

</body>

</html>

运行结果如下图所示:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
图:计数器

注意:在使用 CSS 计数器之前,必须使用 counter-reset 创建计数器。

计数器嵌套

另外,计数器还可以嵌套使用,而且使用 counters() 函数可以在不同级别的嵌套计数器之间插入一个字符串,如下例所示:

<!DOCTYPE html>

<html>

<head>

    <style>

        ol {

            /* 为每个ol元素创建新的计数器实例 */

            counter-reset: ol-list;

            list-style-type: none;

        }

        li:before {

            /* 只增加计数器的当前实例 */

            counter-increment: ol-list;

            /* 为所有计数器实例增加以“.”分隔的值 */

            content: counters(ol-list, ".") "、";

        }

    </style>

</head>

<body>

    <ol>

        <li>item</li>

        <li>item

            <ol>

                <li>item</li>

                <li>item</li>

                <li>item

                    <ol>

                        <li>item</li>

                        <li>item</li>

                    </ol>

                </li>

                <li>item

                    <ol>

                        <li>item</li>

                        <li>item</li>

                        <li>item</li>

                    </ol>

                </li>

            </ol>

        </li>

        <li>item</li>

        <li>item</li>

    </ol>

</body>

</html>

运行结果如下图所示:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传
图:计数器嵌套

通过以上示例我们不难看出,使用 CSS 计数器可以在不借助其它编程语言(例如 JavaScript、PHP
等)的情况下实现简单的计数功能,当需要为某些内容添加序号时非常适用。

原文地址CSS计数器


http://www.kler.cn/news/333204.html

相关文章:

  • Effective C++中文版学习记录(二)
  • 【无人机设计与技术】自抗扰控制(ADRC)的建模与仿真研究
  • MongoDB 索引
  • 世优科技出席36氪2024具身智能大会圆桌对话,入选创新应用案例
  • SOMEIP_ETS_166: SD_TestFieldUINT8
  • 【MySQL】数据库中的内置函数
  • 《程序猿之Redis缓存实战 · 有序集合类型》
  • XSLT 实例:掌握 XML 转换的艺术
  • 22.3 解读k8s服务发现源码
  • Vite+Vue3+SpringBoot项目如何打包部署
  • shadcn-vue 快速入门(2)
  • LLaMA 3 和 OpenAI有哪些相同点和不同点?
  • 昇思学习打卡营第32天|基于ResNet50的中药炮制饮片质量判断模型
  • Middleware---RocketMQ
  • [MAUI]数据绑定和MVVM:MVVM的属性验证
  • C++中list的模拟实现
  • 【c++】条件计数器函数设计
  • 1、Spring Boot 3.x 集成 Eureka Server/Client
  • fatal: urdf 中的 CRLF 将被 LF 替换
  • Jupyter | jupyter notebook 使用 conda 环境