Начнем с терминов.
Классы (class) - это механизм, позволяющий задавать одно и то же свойство стиля для нескольких элементов веб-страницы.
Идентификаторы (id) - атрибут id указывает уникальный идентификатор для элемента HTML (значение должно быть уникальным в HTML-документе).
БЭМ - это методология разработки веб-интерфейсов, которая помогает структурировать и организовывать код HTML и CSS. Она основана на трех основных концепциях: блок, элемент, модификатор.
HTML (HyperText Markup Language) - это язык разметки, используемый для создания структуры и содержания веб-страниц. Одним из важных аспектов в HTML является возможность задавать элементам и компонентам уникальные имена с помощью классов и идентификаторов. В этой статье мы рассмотрим, зачем они нужны, когда их использовать, и как работает методология БЭМ (Блок, Элемент, Модификатор).
Зачем нужны классы и идентификаторы
Классы и идентификаторы позволяют уникально идентифицировать элементы и компоненты на веб-странице. Идентификаторы (задаются через атрибут id
) являются уникальными для всей страницы, тогда как классы (задаются через атрибут class
) могут быть применены к нескольким элементам.
Классы и идентификаторы используются для применения стилей CSS к элементам. Они помогают создавать каскадные таблицы стилей (CSS) и делать внешний вид веб-страницы более привлекательным.
Классы и идентификаторы часто используются в JavaScript для обращения к элементам страницы и добавления им динамического поведения. Например, скрипты могут изменять классы элементов, основываясь на событиях или действиях пользователя.
Когда использовать классы и идентификаторы
Идентификаторы (id) должны использоваться, когда нужно уникально идентифицировать элемент на странице. Например, идентификатор может быть использован для якорей внутри документа.
Классы (class) применяются, когда нужно группировать несколько элементов с общими характеристиками или стилями. Классы могут быть использованы на нескольких элементах.
Методология БЭМ (Блок, Элемент, Модификатор)
Блок представляет собой компонент страницы, который может содержать другие элементы или модификаторы. Например, блок "button" может содержать текст и иконку.
<div class="button">
Кнопка
</div>
Элементы находятся внутри блока и представляют собой его составные части. Они именуются с использованием двойного подчеркивания __
.
<div class="button">
<span class="button__text">
Кнопка
</span>
</div>
Множественные элементы блока, например, элементы списка могут быть названы как -item
:
<ul class="cards__container">
<li class="cards__container-item">
Элемент 1
</li>
<li class="cards__container-item">
Элемент 2
</li>
<li class="cards__container-item">
Элемент 3
</li>
</ul>
Модификаторы используются для изменения внешнего вида или поведения блока или элемента. Они именуются с использованием одинарного подчеркивания _
.
<div class="button button_primary">
Кнопка
</div>
Обращение к классам и идентификаторам из CSS
Чтобы применить стили к классам или идентификаторам, вы можете использовать селекторы. Например, чтобы стилизовать элемент с классом "button", вы можете написать:
.button {
background-color: #007bff;
color: #fff;
}
Из JavaScript вы можете получить доступ к элементам по их классам или идентификаторам с использованием методов, таких как document.querySelector()
или document.getElementById()
.
Пример обращения из JavaScript к элементу по классу:
const buttonElement = document.querySelector('.button');
Перейдем к примерам. Допустим, что согласно дизайн-макету у вас есть 3 прямоугольных блока с определенными размерами и цветом фона. Однако, последний элемент из данного списка имеет отличный от двух других фоновый цвет:
Стоит начать с изучения макета. Мы видим, что у всех трех элементов заданы одинаковые размеры и у двух элементов из трех одинаковый цвет фона. Предположим, что и у третьего элемента изначально был красный цвет фона. Исходя из анализа макета, все три элемента можно классифицировать и задать общие стили:
Задав для всех трех div класс "cards__container-item" и обратившись по данному селектору в CSS мы объявили общие стили для всех трех элементов. Внимание: задав для трех HTML-элементов одинаковый класс - в CSS нам стоит только один раз прописать сценарий для данного селектора. Это будет выглядеть так:
<div class="cards__container-item"></div>
<div class="cards__container-item"></div>
<div class="cards__container-item"></div>
.cards__container-item{
width: 263px;
height: 393px;
background: red;
}
Теперь нам необходимо выделить последний блок из данного списка. Здесь мы прибегнем к модификатору. Запомните: классы в HTML в атрибуте class перечисляются через пробел!
Мы добавили дополнительный класс-модификатор "cards__container-item_blue" к элементу "cards__container-item", который указывает на внешний вид данного элемента. Обратите внимание, что в CSS создан отдельный сценарий и свойство для нового селектора под предыдущим сценарием. Это сделано для переопределения свойства "background". Если бы мы в атрибуте class у HTML-элемента написали бы класс-модификатор, а за ним класс элемента, а в CSS сначала объявили сценарий для модификатора, а затем для элемента, то нужный нам элемент имел бы красный фон, так как очередность классов в HTML и CSS имеет важную роль.
Чем ниже селектор в CSS - тем данный сценарий приоритетнее!
Приоритет элементов
В HTML приоритет классов определяет, какие стили будут применены к элементу, если один и тот же элемент имеет несколько классов, и каждый из них задает свои стили. Приоритет классов определяется по их специфичности и порядку в файле стилей (CSS). Давайте рассмотрим приоритет классов более подробно:
Специфичность (Specificity): Это основной фактор определения приоритета классов в CSS. Каждому селектору присваивается числовое значение специфичности, и чем оно выше, тем выше приоритет. Специфичность определяется следующим образом:
Идентификатор (ID): Селектор с ID имеет более высокий приоритет и получает 100 баллов специфичности.
Классы и псевдоклассы: Селекторы с классами, псевдоклассами и атрибутами имеют средний приоритет и определяются исходя из количества совпадающих классов и псевдоклассов.
Теги и псевдоэлементы: Селекторы с тегами и псевдоэлементами имеют наименьший приоритет.
Примеры специфичности:
#header
(100 баллов) более специфичен, чем.navbar
(10 баллов)..sidebar a
(20 баллов) более специфичен, чемp
(1 балл).Порядок в файле стилей: Если два селектора имеют одинаковую специфичность, приоритет определяется тем, какой из них определен позднее в файле стилей. Если один и тот же стиль задан дважды, последний будет иметь более высокий приоритет.
Пример:
.button {
background-color: red; /* Первое вхождение */
}
.button {
background-color: blue; /* Последнее вхождение, переопределяет
предыдущее значение */
}
В данном случае кнопка будет иметь фон синего цвета, потому что второе правило переопределяет первое.
Важность (Importance): Можно задать важность для стилей, используя ключевое слово
!important
. Если стиль имеет важность, он будет иметь самый высокий приоритет и переопределит любые другие стили, даже если они более специфичны или определены позднее.
Пример:
.button {
background-color: red !important; /* Самый высокий приоритет */
}
.button {
background-color: blue;
}
Кнопка будет иметь фон красного цвета, даже если другой стиль определен последним.
Итак, приоритет классов в HTML определяется специфичностью селекторов, порядком в файле стилей и важностью. В большинстве случаев рекомендуется избегать использования !important
, так как он может делать код менее читаемым и поддерживаемым. Вместо этого старайтесь следовать лучшим практикам и организовывать стили ваших классов так, чтобы избежать конфликтов и создавать читаемый и легко поддерживаемый CSS.
Итог
Классы и идентификаторы в HTML и CSS - это мощные инструменты для структурирования и стилизации веб-страниц. Вот ключевые моменты, которые стоит запомнить:
Цель использования: Классы и идентификаторы предназначены для добавления структуры и стилей в HTML-документ. Классы используются для определения множества элементов с общими характеристиками, в то время как идентификаторы уникальны для каждого элемента.
Использование классов: Классы полезны, когда вы хотите применить стили к нескольким элементам схожего типа. Они позволяют создавать повторно используемые стили и улучшают обслуживаемость кода.
Использование идентификаторов: Идентификаторы (через атрибут
id
) применяются, когда нужно обратиться к конкретному уникальному элементу на странице. Они имеют более высокий приоритет и могут использоваться для навигации и скриптов.Методология БЭМ: БЭМ (Блок, Элемент, Модификатор) - это методология именования классов, которая помогает создавать понятный и легко поддерживаемый код. Блок представляет собой независимый компонент, элемент - часть блока, а модификатор - его измененное состояние.
Пример БЭМ: Например, для создания стилизованных кнопок с БЭМ, вы можете использовать классы вроде
button
(блок),button__label
(элемент) иbutton_primary
(модификатор).Обращение из CSS: Для обращения к классам и идентификаторам из CSS, используйте соответствующие селекторы. Классы указываются с точкой (например,
.button
), а идентификаторы с решеткой (например,#header
).Осторожно с идентификаторами: Используйте идентификаторы осторожно и только тогда, когда это необходимо, чтобы избежать конфликтов и обеспечить читаемость кода.
В заключение, правильное использование классов и идентификаторов в HTML и CSS может значительно упростить создание и поддержку веб-страниц, делая код более читаемым и управляемым. Методология БЭМ помогает организовать именование классов для лучшей структурированности проекта.