- •Введение в css
- •Оформление текста
- •Блочная модль документа
- •Знакомство html5
- •Html5 формы
- •Селекторы ч2
- •Псевдокласс :only-child [12/20]
- •Псевдокласс :only-of-type [13/20]
- •Псевдоэлемент ::before [14/20]
- •Псевдоэлемент ::after [15/20]
- •Псевдоэлементы ::first-line и ::first-letter [18/20]
- •Селекторы ч3
- •Псевдоклассы :invalid и :valid [14/18]
- •Псевдоклассы :in-range и :out-of-range [15/18]
- •Флексбоксы
- •Главная ось, flex-direction [2/31]
- •Поперечная ось [3/31]
- •Распределение флекс-элементов, justify-content [4/31]
- •В начале и в конце главной оси [5/31]
- •Равномерное распределение [6/31]
- •Выравнивание флекс-элементов, align-items [7/31]
- •Эгоистичное выравнивание, align-self [10/31]
- •Перенос флекс-элементов, flex-wrap [13/31]
- •Выравнивание строк флекс-контейнера, align-content [15/31]
- •Порядковый номер флекс-элемента, order [19/31]
- •Блоки одинаковой высоты [30/31]
- •Флексбоксы ч2
- •Особенности свойства margin [2/28]
- •Направление главной оси и внешние отступы [4/28]
- •Базовый размер флекс-элемента, flex-basis [5/28]
- •Коэффициент растягивания элементов, flex-grow [7/28]
- •Пропорциональное растягивание элементов [8/28]
- •Расчёт итогового размера с flex-grow [9/28]
- •Коэффициент сжатия элементов, flex-shrink [10/28]
- •Пропорциональное сжатие элементов [11/28]
Псевдокласс :only-child [12/20]
Псевдокласс :only-child пригодится, когда нужно прописать индивидуальные стили для элемента, который является единственным дочерним элементом внутри родительского контейнера.
Пример:
li:only-child {
...
}
Сработает, когда этот <li> в списке единственный.
Cелектор :only-child эквивалентен селектору elem:last-child:first-child.
Псевдокласс :only-of-type [13/20]
Псевдокласс :only-of-type работает почти так же, как и :only-child. Отличие состоит в том, что он учитывает тип элемента.
Пример:
p:only-of-type {
...
}
В данном случае стили будут применены к элементу p, если это единственный p внутри своего родителя.
Псевдоэлемент ::before [14/20]
Псевдоэлемент before позволяет с помощью CSS добавить псевдотег внутрь другого элемента и оформить его. Cодержимое псевдотега задаётся с помощью свойства content.
Например, у нас есть такой HTML:
<div class="queen heart">
<em>Дама</em>
</div>
Добавим CSS-правило с необычным селектором с двойным двоеточием:
.heart::before { content: "Черви"; }
И HTML изменится вот так:
<div class="queen heart">
<before>Черви</before>
<em>Дама</em>
</div>
Но! Исходный HTML-код не изменится, тег <before> не попадёт в код страницы, а будет «виртуально» существовать где-то в браузере. Поэтому мы и используем приставку псевдо.
Ведёт себя псевдотег так же, как обычный <span> с текстом. Ему можно задавать дополнительные стили, например:
.heart::before {
content: "Черви";
color: red;
}
Чтобы псевдоэлемент появился, ему необходимо задать свойство content. Достаточно даже пустой строки в значении свойства — content: "";.
Псевдоэлемент ::after [15/20]
Псевдоэлемент after аналогичен before. Отличие заключается в том, что он добавляет псевдотег не в начало, а в конец элемента. Например:
.heart::after { content: "Черви"; }
Даст такой результат:
<div class="queen heart">
<em>Дама</em>
<after>Черви</after>
</div>
Псевдоэлементы before и after можно использовать одновременно. Это означает, что с помощью CSS вы можете добавить к любому элементу на странице два псевдоэлемента.
Обратите внимание, что псевдоэлементы пишутся с двойным двоеточием. Этим они отличаются от псевдоклассов, которые используют одинарное двоеточие.
Псевдоэлементы ::first-line и ::first-letter [18/20]
Отвлечемся от карт и обратимся к тексту.
Псевдоэлемент first-line задает стиль первой строки форматированного текста. Длина этой строки зависит от многих факторов, таких как используемый шрифт, размер окна браузера, ширина блока, языка и т.д. В правилах стиля допустимо использовать только свойства, относящиеся к шрифту, изменению цвета текста и фона.
Пример использования:
p::first-line { }
Аналогично псевдоэлемент first-letter определяет стиль первого символа в тексте элемента, к которому добавляется. К этому псевдоэлементу могут применяться только стилевые свойства, связанные со свойствами шрифта, полями, отступами, границами, цветом и фоном.
Пример использования:
p::first-letter { }
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
Селекторы ч3
Ищем в начале строки: [foo^="bar"] [1/18]
В первом курсе про селекторы мы разбирали селектор по атрибутам, когда запись input[type="text"] выберет все элементы input, у которых атрибут type равен text.
У этого механизма есть дополнительные возможности: можно выбирать элементы по вхождению подстроки в значение атрибута.
Запись вида [foo^="bar"] выберет все элементы, у которых значение атрибута foo начинается с подстроки bar.
Представьте, что у вас есть три класса для задания колонок разной ширины, например: column-1, column-2 и column-3.
У этих классов часть свойств повторяется, а разной является только ширина. Чтобы не дублировать CSS-код, вы можете вынести общие свойства колонок в правило с селектором [class^="column-"], а в остальных правилах задать только ширину:
[class^="column-"] {
/* общие свойства: отступы, рамки, фон и т.д. */
}
.column-1 { width: 100px; }
.column-2 { width: 200px; }
.column-3 { width: 300px; }
То есть, первый селектор выберет все дивы с классами, начинающимися на column-:
<div class="column-1"></div>
<div class="column-2"></div>
<div class="column-3"></div>
Обратите внимание, что селектор чувствителен к регистру.
Ищем в конце строки: [foo$="bar"] [2/18]
Селектор вида [foo$="bar"] выбирает все элементы, значение атрибута foo которых оканчивается строкой bar.
Представьте, что у вас на сайте есть раздел с файлами для скачивания в разных форматах и вам нужно для каждого типа файлов добавить свою иконку. Пример разметки:
<a href="batman.pdf">Скачать</a>
<a href="superman.doc">Скачать</a>
В этом случае вы можете назначать иконки в CSS по расширениям файлов:
a[href$=".pdf"] {
/* иконка для PDF */
}
a[href$=".doc"] {
/* иконка для DOC */
}
И снова, селектор чувствителен к регистру.
Поиск подстроки везде: [foo*="bar"] [3/18]
Следующий вариант записи [foo*="bar"]
Будут выбраны все элементы, у которых значение атрибута foo содержит подстроку bar на любой позиции
Среди трёх элементов:
<p class="person-name"></p>
<div class="some-person-info"></div>
<span class="date-person"></span>
селектор [class*="person"] выберет все.
Обратите внимание, что селектор чувствителен к регистру.
Поиск слов внутри строки: [foo~="bar"] [4/18]
Следующая запись: [foo~="bar"].
Такой селектор выберет все элементы, у которых значение атрибута foo содержит слово bar.
Входить должно именно слово, а не просто подстрока. То есть вхождение bar должно содержать с обеих сторон разделители: пробелы или начало/конец строки.
Поиск префиксов: [foo|="bar"] [5/18]
Селектор по атрибутам вида [foo|="bar"]
В данном случае будут выбраны все элементы, у которых значение атрибута foo содержит префикс bar, то есть либо полностью совпадает с bar, либо начинается со строки bar-(наличие знака переноса существенно). Другими словами, используя уже знакомые записи селекторов, этот можно заменить на два: 1. [foo="bar"] — все элементы, у которых значение атрибута foo полностью совпадает со значением bar. 2. [foo^="bar-"] — все элементы, у которых значение атрибута foo начинается со значения bar-.
В случае сразу нескольких атрибутов!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
Для обращения к элементам, которые являются доступными на сайте (не заблокированными), можно использовать псевдокласс :enabled. Заблокированными считаются элементы форм, у которых установлен атрибут disabled. Подробнее об этом атрибуте можно посмотреть в этом курсе
Например:
input:enabled {
/* какие-то стили */
}
И наоборот, если нужно обратиться только к заблокированным элементам, то для этого есть псевдокласс :disabled
Как мы уже рассматривали в предыдущих курсах, есть разные способы запретить редактирование пользователем полей. Одним из таковых является установка атрибута readonly. Значение в данном случае доступно для чтения и копирования, но недоступно для редактирования.
В зависимости от этого параметра существует два селектора, которые позволяют выбирать каждую группу полей
Селектор :read-write выберет все поля доступные для редактирования
Селектор :read-only выберет все поля доступные только для чтения
Пример записи:
input:read-only {}
Мы уже разбирали, что при помощи специального атрибута required можно отметить поля, обязательные для заполнения
Используя селектор :required можно задать отдельные стили для этих полей
Например
input:required {}
Помимо :required существует селектор :optional, выполняющий обратное действие. То есть выберутся все элементы, у которых НЕ указан атрибут required
Пример записи
select:optional {}
При помощи селектора :checked можно обратиться ко всем элементам input с типами checkbox или radio, которые являются выбранными (отмеченными)
Например
input:checked {}
Всем
элементам label стоящим
после отмеченных элементов input установите
цвет текста #1abc9c
input:checked+label{color:#1abc9c;}
