Разбираем CSS свойство Content

Для чего нужно свойство Content в CSS. Как добавить свой элемент возле другого элемента в верстке с помощью Content.

Благодаря CSS вы можете обогатить страницу элементами, которыми она изначально не располагала. Данное действие реализуется с применением псевдо элементов :after и :before. Однако именно свойство content является важнейшим в этом деле.

Именно content обозначает, что вмещают в себя те или иные псевдоэлементы. Кроме того, важно учитывать, что без заданного свойства content ни один из псевдоэлементов просто-напросто не отобразится. А для того, чтобы они отобразились достаточно следующего фрагмента:


content: "";

В нижеприведенном примере, два снеговика отображаются за счет фрагмента content, а сами по себе элементы состоят из Unikode символов.


DIV:before {
    content: "\2603";
    }

See the Pen Content1 by pyampa (@pyampa) on CodePen.


Допустимые значения content:

none, normal – псевдоэлементы скрыты. Актуально в случаях, когда требуется спрятать изначально заданный псевдоэлемент.

<string> - текстовое наполнение. Позволяет добавлять обычный текст, а также юникод символы. (см. вышеприведенный пример). В целях практичного применения станут полезны разнообразные вариации стрелок. Те или иные символы юникода можно отыскать на специализированных сайтах.


DIV:before  {
    content: "Hello";
    }

See the Pen Content2 by pyampa (@pyampa) on CodePen.


See the Pen Content3 by pyampa (@pyampa) on CodePen.


<url> — адреса картинок.


DIV:before  {
    content: url(http://img-fotki.yandex.ru/get/5413/5091629.67/0_5ba12_81d03a82_XS.png);
    }

See the Pen Content4 by pyampa (@pyampa) on CodePen.


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

See the Pen Content5 by pyampa (@pyampa) on CodePen.


Правда, тут появляется проблема лишних запросов к серверу.

Проблему растущего количества запросов к серверу можно решать одним из нижеперечисленных способов:

  1. С помощью спрайта, вставляя иконки в качестве фона в псевдоэлемент или ссылку. В первом случае налицо преимущество: иконки можно расположить не только вертикально, но и в ряд, поскольку визуальную область спрайта будет ограничивать сам псевдоэлемент. В данном случае объем запросов может сократиться до одного, при условии кеширования картинки на устройстве посетителя сайта.
  2. Отдельные изображения можно вставлять с помощью content: url();, предварительно закодировав их через base-64.
  3. С помощью base-64 можно, также, использовать весь предварительно закодированный спрайт в качестве фона псевдоэлемента.

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

Некоторые онлайн-сервисы позволяют без лишних сложностей закодировать изображения в base-64. Полученный на выходе код необходимо вставить в url(). В коде уже имеется информация о том, какой формат имеет содержимое. К примеру: data:image/png;base64.

Рассмотрим на примере инстаграмм иконки, как будет выглядеть код:


[href*="instagram.com"]:before {
    content: url()
  }

Как можно заметить, код довольно длинный. Также, из его содержимого нельзя понять, какого рода изображение размещено, что в свою очередь, лишает возможности редактирования картинки. Если потребуется изменить изображение, необходимо будет вновь преобразовать её с помощью base-64 и вставить по новой.

Однако, на данный момент разработан плагин, позволяющий кодировать изображения и менять их url в автоматическом режиме.

Аналогично вставляется SVG.


DIV:before{
    content: url('data:image/svg+xml;utf8,');
    }

Подобный способ довольно удобен, однако воспринимается не всеми браузерами. К примеру, Mozilla, в отличие от Chrome эту кодировку не распознает.

<counter> - функция подсчета. Благодаря данному значению, можно задать нумерацию не только спискам, но и прочим страничным элементам. К примеру, это может быть раздел публикации:


BODY {
  counter-reset: h2-counter;
  counter-reset: p-counter;
  }
DIV {
  counter-increment: h2-counter;
  }
  H2:before {
    content: counter(h2-counter) ". ";
    }
  P:before {
    content: counter(p-counter) ". ";
    counter-increment: p-counter;
    }

Задать счетчику название можно при помощи counter-reset.
Увеличить значение счетчика поможет counter-increment.

Вывести показания счетчика в роли содержания псевдоэлемента можно, используя content: counter(имя счетчика)

See the Pen Content6 by pyampa (@pyampa) on CodePen.



attr(<identifier>) – это значение позволяет вывести содержание имеющегося атрибута. Довольно удобно при выводе печатных версий href атрибутов, а также других популярных эффектов.


A:before  {
    content: attr(title);
    }

See the Pen Content7 by pyampa (@pyampa) on CodePen.


open-quote, close-quote эти значения предназначены для того, чтобы открыть и закрыть кавычки. Выбор используемых символлов регулируется свойством quotes. При его отсутствии, применяются значения по умолчанию, отображение которых зависит от браузера пользователя.


blockquote {
    quotes: '"' '"' "'" "'";
    }
  blockquote:before {
    content: open-quote;
    }
  blockquote:after  {
    content: close-quote;
    }

See the Pen Content8 by pyampa (@pyampa) on CodePen.


no-open-quote, no-close-quote – эти значения визуально убирают кавычки. Тем не менее, уровень вложенности кавычек по-прежнему будет учтён.

Довольно много интересных особенностей применения псевдоэлементов, в том числе и множественных изложены в спецификации (http://www.w3.org/TR/css3-content/). Однако на сегодняшний день реализация описываемого встречается не часто.


Comments