Как создать сайт?
Главная Карта сайта Учебник HTML Учебник CSS Что такое CSS? Внедрение CSS. Свойства текста. Свойства шрифта. Цвет и фон. Границы элемента. Классы и id селекторы. Размеры элемента. Поля и отступы. Курсоры. Форматирование. Поплавки. Позиционирование. Стиль списка. Полоса прокрутки. Псевдоклассы. Псевдоэлементы. Стиль первой буквы Стиль первой строки Контент Псевдоэлемент ::selection Полезные советы Учебник CSS 3 Публикация сайта Раскрутка сайта Справочник Уроки  Форум  Новости От автора

  На сайте компании Ритуальных услуг:
Сделайте наш сайт домашней страничкой!

Глава 16

Псевдоэлементы.

Псевдоэлементы - это особый вид свойств CSS, которые позволяют работать не над самим элементом, а над его отдельной частью.

Вот перечень всех псевдоэлеметов:

Так же как и в случае с псевдоклассами, псевдоэлементы используются согласно следующего синтаксиса:

p:first-letter { color:#ff0000}

где:

p - селектор, к которому применяется псевдоэлемент.
:first-letter - после двоеточия собственно псевдоэлемент. *примечание
{color:#ff0000} - блок объявления стилей в фигурных скобках.

В данном случае мы указали, что первая буква всех параграфов будет красного цвета.

Ну что ж давайте пробежимся по перечисленным псевдоэлементам.

Стиль первой буквы.

Псевдоэлемент first-letter задаёт стиль первой буквы в каком либо текстовом блоке, проще говоря, без особых усилий позволяет сделать "буквицу". Вы заметили, что на этом сайте первые буквы в абзацах отличны цветом и размером от других букв? - это и есть пример работы псевдоэлемента first-letter.

Ну а если Вам этого примера мало можете взглянуть на ещё один:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>Псевдоэлемент first-letter.</title>
<style type="text/css">
p {
font: 16px Arial;
}
p:first-letter {
font: bold 24px Verdana;
color:#ff0000
}
</style>
</head>
<body>
<p>Мало кто знает, как много надо знать для того, что бы знать, как мало мы знаем.<p>
<p>Осмысливая мысли, в смысле смысла, есть смысл, помыслить о немыслимом..<p>
</body>
</html>
смотреть пример  

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

Стиль первой строки.

Псевдоэлемент first-line определяет стиль первой строки в текстовом блоке.

Пример:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>Псевдоэлемент first-line.</title>
<style type="text/css">
body {background-color: #fffacd}
p {color: #005}
p:first-line {
font: 16px Arial;
color: #f00
}
</style>
</head>
<body>
<p>Если бы при приеме на работу… … …</p>
<p>Однажды молодой сисадмин … … …</p>
</body>
</html>
смотреть пример  

Честно признаться, я не знаю в каких ситуациях действительно целесообразно применять псевдоэлемент first-line, хотя не исключаю, что такие ситуации бывают. Обусловлено это в первую очередь тем, что в зависимости от расширения экрана, размера шрифта, интервала между словами и символам и т.д. первая строка в текстовом блоке будет разной длины, что не позволяет веб мастеру полностью контролировать стиль данного текстового блока.

Контент.

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

Всё вместе пишется так:

p:after {content: "Конец, а кто слушал молодец!!"; }

Теперь после каждого параграфа будет добавляться надпись: "Конец, а кто слушал молодец!!"

Значением свойства content может быть:

Пример:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>Псевдоэлементы after и before</title>
<style type="text/css">
*:before {color: #00f; font-variant: small-caps;}
*:after {color: #f00; font-variant: small-caps;}
body:before {content: "начало документа";}
body:after {content: "конец документа";}
p:before {content: "анекдот:";}
p:after {content: ":-)"; font-size: x-large;}
ul {list-style-type: none;}
li:before {content: "№ "; color: #0f0;}
h4:before{content:url(graphics/marker.gif);}
q:before {content: open-quote; font-size: 30px;}
q:after {content: close-quote; font-size: 30px;}
img:after {content:attr(src);}
</style>
</head>
<body>
<hr>
<h4>Заголовок с сердечком.</h4>
<h4>Параграфы с добавлением слова "анекдот:" вначале и смайлика в конце:</h4>
<p>Если бы при приеме на работу...</p>
<p>Однажды молодой сисадмин...</p>
<h4>После рисунка добавляется значение его атрибута: "src" - путь к рисунку:</h4>
<img src="graphics/fon.jpg">
<h4>Цитата в кавычках:</h4>
<q>Лёд тронулся, господа присяжные заседатели!</q>
<h4>Список с нестандартными маркерами:</h4>
<ul>
<li> Первый
<li> Второй
<li> Третий
</ul>
<hr>
</body>
</html>
смотреть пример  

Чувствую перехитрил я с примером, поэтому несколько комментариев к нему:

Звездочка перед псевдоэлементом *:псевдоэлемент{свойство} говорит о том, что указанные правила стиля распространяются на все элементы. Так в нашем примере текст в начале везде синий, а в конце везде красный, если он конечно не указывается дополнительно, как например в случае с зелёными "маркерами" в списке из примера.

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

Спецсимволы HTML (например, спецсимвол: &para;), будут отображаться простым текстом (&para; а не ) так что если необходимо добавить какую либо хитрую закорючку используйте юникод.

Псевдоэлементы after и before, как и свойство content не поддерживаются браузерами Internet Explorer 7 и ниже.

Псевдоэлемент ::selection.

Псевдоэлемент ::selection (я не опечатался, пишется именно с двумя двоеточиями) указывает на стиль выделенного пользователем текста.

Данный псевдоэлемент появился на свет только в спецификации CSS3 и к сожалению поддерживается не всеми браузерами так IE его полностью игнорирует, а браузер Firefox использует свой аналогичный псевдоэлемент ::-moz-selection который официально не входит в спецификацию CSS.

Пример:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>Псевдоэлемент ::selection</title>
<style type="text/css">
p::selection {
color: #f00;
background: #0f0;
}
</style>
</head>
<body>
<p>Попробуете выделить данный текст, как будто Вы собираетесь его скопировать. Если Ваш браузер (например Opera 9.6 и выше) поддерживает псевдоэлемент ::selection, Вы увидите, что выделенный текст станет красным, а его фон зелёным.</p>
</body>
</html>
смотреть пример  

К данному псевдоэлементу можно применить только следующие CSS свойства: color, background и background-color.

Полезные советы: