ЛУЧШИЙ САЙТ ДЛЯ ВЕБ-РАЗРАБОТЧИКОВ

CSS Учебник

CSS СТАРТ CSS Введение CSS Синтаксис CSS Селекторы CSS Как подключить CSS Цвета CSS background-color CSS border CSS margin CSS padding CSS height/width CSS Блочная модель CSS Контур CSS Текст CSS Шрифты CSS Иконки CSS Ссылки CSS Списки CSS Таблицы CSS display CSS max-width CSS position CSS overflow CSS float/clear CSS inline-block CSS Выравнивание CSS Комбинаторы CSS Псевдо-классы CSS Псевдо-элементы CSS opacity/transparency CSS Панель навигации CSS Выпадающие списки CSS Галерея изображений CSS Спрайты изображений CSS Селекторы атрибутов CSS Формы CSS Счётчики CSS Макет веб-сайта CSS Единицы CSS Специфичности

CSS Продвинутый

CSS Закругленные углы CSS Границы изображения CSS Фоны CSS Цвета CSS Градиенты CSS Тени CSS Эффекты текста CSS Веб-шрифты CSS 2D Трансформации CSS 3D Трансформации CSS Переходы CSS Анимации CSS Подсказки CSS Стили изображений CSS Подгонка объекта CSS Кнопки CSS Нумерация страниц CSS Несколько столбцов CSS Пользовательский интерфейс CSS Переменные CSS Размеры блоков CSS Флексбокс CSS Медиа-запросы CSS Примеры медиа-запросов

CSS Адаптивный

RWD Введение RWD Область просмотра RWD Вид сетки RWD Медиа-запросы RWD Изображения RWD Видео RWD Фреймворки RWD Шаблоны

CSS Grid (Сетка)

Grid Введение Grid Контейнер Grid Элементы

CSS Примеры

CSS Шаблоны CSS Примеры CSS Викторина CSS Упражнения CSS Сертификат

CSS Справочники

CSS Справочник CSS Селекторы CSS Функции CSS Справочник аудио CSS Безопасные веб-шрифты CSS Анимация CSS Единицы CSS PX-EM Конвертер CSS Цвета CSS Значения цвета CSS Значения по умолчанию CSS Поддержка браузерами

CSS3. Уроки для начинающих

CSS Комбинаторы


CSS Комбинаторы

Комбинатор - это то, что объясняет отношения между селекторами.

Комбинаторы — разновидность специальных селекторов, привязывающая стиль к элементу веб-страницы на основании его местоположения относительно других элементов.

Комбинаторы, как и следует из названия, предназначены для сочетания (комбинирования) различных селекторов.

Выбрать все элементы <p> внутри элемента <div>:

Div (родитель)

Параграф 1 в div.

Div в div.

Параграф 2 в div.

Параграф 3. Не в div.

Селектор CSS может содержать более одного простого селектора. Между простыми селекторами мы можем включить комбинатор.

В CSS есть четыре разных типа комбинатора:

  • селектор потомок (пробел)
  • селектор дочерний (>)
  • селектор соседний родственный (+)
  • селектор общий (~)

Селектор потомок

Селектор потомок соответствует всем элементам, которые являются потомками указанного элемента.

В следующем примере выбираются все элементы <p> внутри элементов <div>

Пример

div p {
  background-color: yellow;
}
Попробуйте сами »

Селектор дочерний

Дочерний селектор выбирает все элементы, которые являются дочерними для указанного элемента.

В следующем примере выбираются все элемента <p> которые являются дочерними для элемента <div>:

Пример

div > p {
  background-color: yellow;
}
Попробуйте сами »

Соседний родственный селектор

Селектор соседний родственный выбирает все элементы, которые являются соседними родственными указанного элемента.

Родственные элементы должны иметь один и тот же родительский элемент, и "соседние" означают "следующий после".

В следующем примере выбираются все элементы <p>, которые следуют сразу после элементов <div>:

Пример

div + p {
  background-color: yellow;
}
Попробуйте сами »

Селектор общий

Общий селектор одноуровневого элемента выбирает все элементы, являющиеся одноуровневыми элементами указанного элемента.

В следующем примере выбираются все элементы <p>, которые являются родственными элементам <div>

Пример

div ~ p {
  background-color: yellow;
}
Попробуйте сами »

Проверьте себя с помощью упражнений!


Все селекторы CSS комбинатора

Селектор Пример Описание примера
элемент элемент div p Выбрать все элементы <p> внутри элементов <div>
элемент>элемент div > p Выбрать все элементы <p> у которых родителем является элемент <div>
элемент+элемент div + p Выбрать все элементы <p> которые следуют сразу после элементов <div>
элемент1~элемент2 p ~ ul Выбрать каждый элемент <ul>, которому предшествует элемент <p>