详细介绍CSS计数器


本文摘自PHP中文网,作者V,侵删。

css计数器效果是指使用CSS代码实现随元素的数目增多, 数值也跟着变大的效果, 有点类似于<ol>, 但是比ol更灵活。

(推荐教程:css视频教程)

CSS计数器有两个属性 (counter-reset 和 counter-increment) 和一个方法 (counter() / counters()), 下面以次讲解:

1. counter-reset

属性counter-reset顾名思义就是 计数器-重置 的意思, 其实主要作用就是给计数器起个名字, 如果可能, 顺便告诉下从哪个数字开始计数, 默认是0, 注意默认是0, 而不是1, 在网上可能会看到有很多例子默认显示的第一个数字都是1, 而不是0, 这是因为受到 counter-increment 的影响, 后面详细讲解

先看一个简单的例子

1

2

<div>下面将出现的数字</div>

<div class="counter"></div>

1

2

3

4

5

6

7

8

.counter {

    counter-reset: resetname 2;

    font-size: 24px;

    color: #f66;

}

.counter:before {

    content: counter(resetname);

}

7478a14f5a773a73955e882dd205046.png

如果将conter-reset 后面的2去掉, 那下面出现的数字就是 0

counter-reset 的计数重置可以是复数, 如 -2, 也可以是小数, 如 2.99, 不过, IE和FireFox对此都不认识, 认为是不合法的数值, 会当做0来处理, 在Chrome下, 任何小数都是向下取整, 如 2.99 会当成 2 来处理.

你以为到此为止了? 当然不是! counter-reset还有一手, 就是多个计数器同时命名, 列如:

1

2

3

4

5

6

7

8

9

10

11

.counter {

    counter-reset: first 2 second 3;

    font-size: 24px;

    color: #f66;

}

.counter:before {

    content: counter(first);

}

.counter:after {

    content: counter(second);

}

6740c3787026d032dfb19d71d48ef20.png

另外, counter-reset 还可以设置为 none, 和inherit, 取消重置以及继承重置.

2. counter-increment

属性 counter-increment 顾名思义就是 计数器递增的意思, 值为counter-reset的一个或者多个关键字, 后面可以跟数字, 表示每次计数的变化值, 如果省略则使用默认变化值 1

CSS计数器的技术有一套自己的规则, 我们称之为 "普照规则", 具体来讲就是, 普照源 (counter-reset) 唯一, 每普照(counter-increment)一次, 普照源增加一次计数

于是就能解决上面所说的 "默认值0"的问题了, 通常我们在使用计数器的时候, 都会使用counter-increment , 这个肯定要用, 不然怎么递增呢.

1

2

3

4

5

6

7

8

9

.counter {

    counter-reset: incerment 2;

    counter-increment: incerment;

    font-size: 24px;

    color: #f66;

}

.counter:before {

    content: counter(incerment);

}

5bb7dee06547194e22a8ad55f190f8f.png

这个普照元素也可以写直接写到为元素上, 效果和上面一样, 也是递增1, 如果父元素和子元素都写了, 那么父元素递增一次, 子元素递增一次, 最后的结果就是递增两次

正如之前提到的, 这个变化值不一定都是1, 可以灵活设置, 比如

1

counter-increment: incerment 2;

变化值也可以是负数, 比如:

1

2

3

4

5

6

7

8

9

.counter {

    counter-reset: incerment 5;

    counter-increment: incerment -2;

    font-size: 24px;

    color: #f66;

}

.counter:before {

    content: counter(incerment);

}

4bb08354e5ef339c30a01005928f714.png

值也可以是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

1

2

3

4

5

6

7

8

9

.counter {

    counter-reset: styleType 2;

    font-size: 24px;

    color: #f66;

}

.counter:before {

    counter-increment: styleType;

    content: counter(styleType, lower-roman);

}

4100f8a59851392d4a4e03292ab4c1f.png

counter 还支持级联, 也就是说, 一个content 属性可以有多个 counter() 方法

1

2

3

4

5

6

7

8

9

.counter {

    counter-reset: cascaderOne 2 cascaderTwo 3;

    font-size: 24px;

    color: #f66;

}

.counter:before {

    content: counter(cascaderOne) '\A' counter(cascaderTwo);

    white-space: pre;

}

ad847141f9f47123015619a3139cd5c.png

下面介绍一下 counters() 方法, 看似只比counter多个 s , 但却有着不同的意思, counters 几乎可以说是嵌套计数器的代名词.

我们平时写的时候不可能都是1, 2, 3, ..., 还有比如 1.1, 1.2, 1.3...等类似的序号, 前者就是counter()干的事, 后者就是counters()干的事

counters的基本用法

1

counters(name, string, style);

其中 string 参数是字符串, 需要用引号包含, 是必须参数, 表示子序号的连接符, style还是和counter的第二个参数一样

下面一个完整的demo:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

<!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>

ac2b9205070f78af4f4249f01879c6a.png

相关推荐:CSS教程

以上就是详细介绍CSS计数器的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

vue怎么引用css

如何利用css实现圆环效果

css如何实现隐藏滚动条

深入浅析css 布局和 bfc

css怎么让超链接不加下划线

css怎么把文字居中

不能忘却的悼念:将网页背景变为黑白色调教程

如何使用css设置框架内文本的垂直位置

css怎么设置变成小手

css怎么实现内容不可选

更多相关阅读请进入《css》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...