Перейти к содержанию

counter-increment

Свойство counter-increment предназначено для увеличения значения счётчика приращений, который задается свойством counter-reset.

Такой счётчик подсчитывает количество отображений элементов на странице и может выводиться с помощью свойства content и псевдоэлементов ::after и ::before. Это позволяет создавать списки (в том числе многоуровневые), в которых нумерация и вид задаются через стили.

Списки, счетчики, генерируемый контент

Синтаксис

/* Increment "my-counter" by 1 */
counter-increment: my-counter;

/* Decrement "my-counter" by 1 */
counter-increment: my-counter -1;

/* Increment "counter1" by 1, and decrement "counter2" by 4 */
counter-increment: counter1 counter2 -4;

/* Do not increment/decrement anything: used to override less specific rules */
counter-increment: none;

/* Global values */
counter-increment: inherit;
counter-increment: initial;
counter-increment: unset;

Значения

none
Запрещает увеличение счётчика для текущего селектора.
<переменная>
Задаёт одну или несколько переменных, для которых требуется изменить значение счётчика. Переменные разделяются между собой пробелом.
<число>
Определяет значение приращения счётчика. По умолчанию оно равно 1. Допускается использовать только положительные целые числа, отрицательные целые числа и ноль.

Возможные сочетания значений свойств counter-reset и counter-increment показаны в табл. 1.

Табл. 1. Изменение нумерации списка
КодРезультат
LI { list-style-type: none; }
OL { counter-reset: list -1; }
LI:before {
counter-increment: list;
content: counter(list) ". ";
}

Список начинается с нуля.

0, 1, 2

LI { list-style-type: none; }
OL { counter-reset: list; }
LI:before {
counter-increment: list 2;
content: counter(list) ". ";
}

Выводятся все чётные числа.

2, 4, 6

LI { list-style-type: none; }
OL { counter-reset: list -1; }
LI:before {
counter-increment: list list;
content: counter(list) ". ";
}

Выводятся все нечётные числа.

1, 3, 5

LI { list-style-type: none; }
OL { counter-reset: list 9; }
LI:before {
counter-increment: list;
content: counter(list) ". ";
}

Список начинается с 10.

10, 11, 12

Примечание

Для элементов, у которых установлено display: none, значение счётчика не меняется.

Значение по-умолчанию:

counter-increment: none;

Применяется ко всем элементам

Спецификации

Поддержка браузерами

Can I Use css-counters? Data on support for the css-counters feature across the major browsers from caniuse.com.

Описание и примеры

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <title>counter-increment</title>
    <style>
      body {
        counter-reset: heading; /* Инициируем счетчик */
      }
      h2:before {
        counter-increment: heading; /* Указываем идентификатор счетчика */
        content: 'Глава ' counter(heading) '. '; /* Выводим текст перед содержимым тега <h2> */
      }
    </style>
  </head>
  <body>
    <h2>Теория ловли льва в пустыне</h2>
    <h2>Методы инверсной кинематики</h2>
    <h2>Ловля льва численными методами</h2>
  </body>
</html>