• 46433
  • 493
  • 26
Нравится блог?
Подписывайтесь!

Автоматическая нумерация с помощью CSS счетчиков

Введение

Часто когда вы пишете текст вам нужно пронумеровать разделы и составить оглавление. Вы можете пронумеровать их непосредственно в коде, но это может быть трудоёмким, если вы будете в последствии редактировать этот текст то вам придётся изменять заново всю нумерацию. CSS2.1 дает вам автоматический способ нумерации использую CSS счётчики, и эта статья будет про то как их использовать. Есть только одно "но": CSS счётчики не поддерживает Internet Explorer, но обещают поддержку в Internet Explorer 8.

Установка счётчика

Первым делом нужно обнулить счётчик и дать ему имя. Это можно сделать с помощью свойства counter-reset, например:

body { counter-reset: section; }

Эти действия обнулят счётчик к 0 на элементе body и присваивает ему имя section. Вы можете задать любое понравившееся вам имя. Это свойство также может иметь второе дополнительное значение, которое устанавливает начальное значение счётчика. Например если вы хотите чтобы нумерация начиналась с 5 то вы можете написать так:

body { counter-reset: section 4; }

Приращение счётчика

Следующим шагом будет установка когда счётчик увеличивается и каким значением. Это может определено свойством counter-increment. Если значение не установлено, то используется приращение счётчика по умолчанию.

body { counter-reset: section 4; }
h2 { counter-increment: section; }

Если вы хотите прирост счётчика по два, то:

h2 { counter-increment: section 2; }

Свойство принимает также нулевое и отрицательные значения. Если счётчик одновременно сбрасывается и приращивается на одном и том элементе, то сначала счётчик будет сброшен, а потом увеличен, например в следующем примере значение счётчика всегда будет 2:

h2 { counter-reset: section;
     counter-increment: section 2; }

Отображение счётчика

После того как счётчик установлен, нужно вывести его на страницу. Вывод осуществляется с помощью свойств content, counter, и псевдокласса :before

body { counter-reset: section 4; }
h2 { counter-increment: section; }
h2:before { counter(section) ". "; }

Смотрите пример

.

Использование двух и более счётчиков.

Можно использовать больше одного счётчика. В следующем примере будет показано как использовать два счётчика, чтобы установить нумерацию для разделов и подразделов. В каждом разделе счётчик подраздела будет сбрасываться.

body { counter-reset: section; }
h2 { counter-increment: section;
       counter-reset: sub-section;
}
h2:before, h3:before { content: counter(section) "." counter(sub-section) " "; }
h3 { counter-increment: sub-section; }

Смотрите пример

.

Вложенные счётчики.

Кроме того как определять счётчики для каждого раздела/подраздела есть так же функция counters() для создания вложенных счётчиков. Это прекрасно работает для элементов типа список, где списки могут быть вложены друг в друга.Это не работало бы в примерах выше, потому что там подразделы не были вложены в разделы. Вложенные счётчики могут быть установлены так:

ol { counter-reset: section;
    list-style-type: none;
}
ol li { counter-increment: section; }
ol li:before { content: counters(section, ".") ". "; }

Это увеличит счётчик на каждом элементе списка, независимо от того сколько вложенных списков. Важно сбросить счётчик в нужном месте, чтобы обнулить его для каждого из вложенных элементов. В нашем случае счётчик сбрасывается на элементе ol. В следующем примере первый вложенный список начнётся с 1.1 и будет увеличиваться 1.2, 1.3 и т.д. Второй вложенный список начнётся с 1.1.1 и далее 1.1.2, 1.1.3.

  1. item 1
    1. sub item 1
      1. sub-sub item 1
      2. sub-sub item 2
      3. sub-sub item 3
    2. Sub item 2
  2. item 2

Смотрите пример

.

Стилизация счётчиков.

Так же во всех случаях вторым аргументом counter можно использовать значения из свойства list-style-type. Например:

h2:before { content: counter(section, upper-alpha) ". "; }

Смотрите пример.

Эта статья является вольным переводом статьи: Automatic numbering with CSS Counters

Вы также можете почитать эту и другие статьи на моем блоге

30 октября 2008, 8:14
934

Загрузка...

Комментарии

Здорово, конечно, но разве не легче использовать нумерованные списки?

А CSS Level 3 это гигантский фейл. Еще чуть-чуть, и он превратится в новый язык программирования, defeating the purpose...
rOOse
0
0
А если мне нужны дивы? Вот заказчик скажет разбейся но не списком а дивами сверстай))) Кстати это не левел 3, а 2.1
Вот пример верстки, так на быструю руку накиданный: Example
А вложить div в li разве нельзя? :)

>Кстати это не левел 3, а 2.1
Угу, точно. Я просто не осилил спеку дальше CSS Box Model. =)
rOOse
0
0
>А вложить div в li разве нельзя? :)

Мдяя... двойка мне))) я почему-то думал что в li нельзя div)))
Ну, а если мне цифры нужны в конце, а не в начале?
>Ну, а если мне цифры нужны в конце, а не в начале?
Как это? Это чтобы поместить цифры справа от текста?

За такую типографику тебя повесят дизигнеры. :D
))) Да нет, ты пример смотрел который в комментариях? вот там цифры отдельно же.
Да, поглядел примерчик.

Наверное, можно сделать с помощью вложенных div + (не)много магии позиционирования CSS. :) (задать padding элементов, или еще там что)
Ага можно и так)))
Приятно поговорить с человеком который в теме)))
spawn
0
0
угу уже зачитал на девопере. практическая ценность низкая, ибо 6 осел.
helgi
0
0
Использовать это, конечно, можно, но, увы, только когда без номеров будет graceful degradation, а не потеря функциональности.
rOOse
0
0
Да осел это беда, но надо уже исключать 6 IE из списка поддерживаемых браузеров)))
spawn
0
0
сам об этом мечтаю но думаю что не раньше чем через год это чудо произойдет =)

Оставьте свой комментарий

Спасибо за открытие блога в Yvision.kz! Чтобы убедиться в отсутствии спама, все комментарии новых пользователей проходят премодерацию. Соблюдение правил нашей блог-платформы ускорит ваш переход в категорию надежных пользователей, не нуждающихся в премодерации. Обязательно прочтите наши правила по указанной ссылке: Правила

Также можно нажать Ctrl+Enter

Популярные посты

Мысли вслух. Почему казахи перестали общаться с родственниками и ходить в гости?

Мысли вслух. Почему казахи перестали общаться с родственниками и ходить в гости?

Дастархан в те времена был скромен. Не было понятия «сынау» - осуждения кто как живет, какой в доме ремонт и т.д. Пока взрослые обсуждали задержку заработной платы, мы играли в армию, жмурки, строили городки...
socium_kzo
5 дек. 2016 / 15:19
  • 22534
  • 28
Верховный Суд презентовал комментарий к Гражданскому процессуальному кодексу

Верховный Суд презентовал комментарий к Гражданскому процессуальному кодексу

ГПК содержит 505 статей, многие из которых написаны несколько сложным юридическим языком. Однако теперь понять их можно проще и без обращения к юристу.
RuSnake
6 дек. 2016 / 10:31
  • 10860
  • 0
Японец о Казахстане: «Ваши девушки уж сильно себе набивают цену...»

Японец о Казахстане: «Ваши девушки уж сильно себе набивают цену...»

"Мужчины должны у вас тут права качать, ибо их процент в вашей численности населения уступает проценту женщин". Я машинально начала уверять, что у нас в стране таковых не имеется...
Sapientia
5 дек. 2016 / 10:52
  • 10233
  • 71
Известный европейский фотограф показал истинную красоту казашек

Известный европейский фотограф показал истинную красоту казашек

С 26 по 30 ноября в Алматы гостил известный европейский фотограф Ян Маклайн в рамках реализации совместного проекта с Казахстаном. Подробности не уточняются, однако ходят слухи о том, что этот...
Muchacho55
7 дек. 2016 / 18:29
  • 7315
  • 8
Распил 1 млрд долларов или спасение для Алматы? В 2017-м начнётся строительство БАКАД

Распил 1 млрд долларов или спасение для Алматы? В 2017-м начнётся строительство БАКАД

Конечно, Алматы заслужил эту дорогу. Невзирая на все издержки, которые могут возникнуть. Заслужил и как крупнейший город Казахстана, и как субъект, формирующий своими налогами около четверти всех...
merurg
7 дек. 2016 / 12:35
  • 7020
  • 19
10 причин, по которым я не смогла работать учителем. Не только в зарплате дело, ребята

10 причин, по которым я не смогла работать учителем. Не только в зарплате дело, ребята

Я почти год проработала в школе, и когда уходила оттуда, была самым счастливым человеком в мире. Тот год, честно говоря, я и сейчас вспоминаю с ужасом.
demonica
6 дек. 2016 / 17:21
  • 5615
  • 78
На самом деле дела плохи: казахстанские школьники на 49-м, а не на 12-м месте по математике

На самом деле дела плохи: казахстанские школьники на 49-м, а не на 12-м месте по математике

О том, как масс-медиа раздула миф о казахстанских вундеркидов в розовый воздушный шар, пока его не проколола правда-иголка. Получается, что казахстанские дети не могут применить теорию в практике...
ardakzhurynov
7 дек. 2016 / 0:17
  • 5055
  • 35
Почему Дональд Трамп назвал Казахстан чудом. Президент подтягивается по географии

Почему Дональд Трамп назвал Казахстан чудом. Президент подтягивается по географии

Трамп и не подозревает, что 16 декабря 1991 Казахстан не создал, а восстановил свою национальную государственность. Иначе бы он упомянул не только 25 лет, а больше чем 550 лет казахской истории.
Stehlikova
2 дек. 2016 / 9:02
  • 5258
  • 88
Молчание врачей. Дети ЮКО, заражённые ВИЧ 10-11 лет назад, узнают о диагнозе-приговоре

Молчание врачей. Дети ЮКО, заражённые ВИЧ 10-11 лет назад, узнают о диагнозе-приговоре

Как сообщают новостные издания, в ближайшее время в Южном Казахстане 102 детям в возрасте 11-12 лет сообщат об их страшном диагнозе. Все эти дети были заражены ВИЧ, причём большинство было инфицировано по вине врачей.
openqazaqstan
2 дек. 2016 / 13:57
  • 4555
  • 4