Застосування мультикласів у CSS - Блог ITVDN
ITVDN: курси програмування
Відеокурси з
програмування
УКР
  • РУС
  • УКР

    Вибери свою IT спеціальність

    Підписка
    УКР
    • РУС
    • УКР

    Застосування мультикласів у CSS

    advertisement advertisement

    Введение в мультиклассы.

    В данной статье мы познакомимся с так называемыми сложными селекторами, особенностями их применения. Для более простого восприятия материала рекомендуем просмотреть пятый видео урок из курса HTML & CSS.

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

    Селектором может быть любой элемент или HTML-тег, для которого возможно задание неких правил форматирования. Принцип определения селекторов довольно простой и имеет следующий синтаксис: Name {Style_rules}.


    Здесь Name – это имя любого элемента на вашей странице, а Style_rules – описание правил стиля, которые вы собираетесь применить к элементу.

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

    <head>

    Универсальный селектор css

        <title>CSS title>

        <style>

    /*Используем универсальный селектор, который обозначается "*" */

            * {

            color:forestgreen;

            }

       style>

    head>

    <body>

        Text1

        <p>Text2p>

        <div>Text3div>

        <br />

        <span>Text4span>

    body>

    В случае, когда необходимо одновременно задать один стиль для двух и более элементов, их перечисляют через запятую: 

    <head>

    Используем перечисление селекторов

        <title>CSStitle>

        <style>

            /*Используем перечисление селекторов p, div */

            p, div {

            color:forestgreen;

            }

        style>

    head>

    <body>

        Text1

        <p>Text2p>

        <div>Text3div>

        <br />

        <span>Text4span>

    body>

    В случае, когда необходимо задать уникальное имя для элемента и по нему изменить его стили или обратиться через JavaScript, целесообразно использовать идентификатор, изредка называемый «ID селектором».

    Поскольку при создании html-документа невозможно отказаться от определенной иерархии вложенности, важно задуматься о том, чтобы стили для вложенных элементов применялись корректно. Целесообразно воспользоваться конструкцией из вложенных селекторов. В самом простом случае получим следующую конструкцию: name1 name2 {Style_rules}, где name1 – родительский элемент, name2 – дочерний (вложенный) тег. При этом подразумевается следующая разметка <name1><name2>...name2>name1>.

    Иерархия вложенности селектрово<head>

        <title>CSStitle>

        <style>

            div p {

                background-color: darkgrey;

                color: red;

                font-size: 20px;

            }

        style>

    head>

    <body>

        <p>Параграф 1 p>

        <div>

            <p>Параграф 2 p>

        div>

    body>

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

    Данная конструкция имеет следующий синтаксис: #Name { Style rules }. Стоит помнить, что имена идентификаторов должны быть уникальными, дабы не вызывать коллизий при обращениях, начинаться с латинских символов, в них разрешено включать символы дефиса и нижнего подчеркивания «-», «_». Когда необходимо применить стили из идентификатора определенному тегу, используется атрибут id, которому передается значение – имя идентификатора без решетки.

    Идентификатор селектора CSS<head>

        <title>CSStitle>

        <style>

            #id1 {

                background-color: #ffd800;

                color: #ff0000;

                font-size: 40px;

            }

        style>

    head>

    <body>

        <p id="id1">Параграф 2 p>

    body>

    Порой при определении идентификатора используется конструкция name#id_name {Style rules}, где name может обозначать любой тег. Подобная конструкция ограничивает возможность применения стилей, определенных в идентификаторе только к тегам, одноименным указанному в определении.

    Что касается применения классов, они актуальны  тогда, когда необходимо задать правила форматирования для определенного селектора или же для нескольких элементов. Существуют следующие варианты использования классов:

    .class_name {Style rules}

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

    Name.class_name {Style rules}

    Таким образом накладываются ограничения на применение правил из класса лишь в одноименных тегах Name.

    <head>

    Способы применения классов     <title>CSStitle>

        <style>

            .myFirstClass {

                background-color: darkcyan;

                color: darkgreen;

                font-size: 40px;

            }

            div.mySecondClass {

                background-color: darkcyan;

                color: darkgreen;

                font-size: 20px;

            }

        style>

    head>

    <body>

        <p class="myFirstClass">Параграф 1 p>

        <p class="mySecondClass">Параграф 1p>

        <div class="mySecondClass">Параграф 1 div>

    body>

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

    Использование нескольких классов<head>

        <title>CSStitle>

        <style>

            .myFirstClass {

                background-color: darkcyan;

            }

            .mySecondClass {

                color: darkgreen;

                font-size: 20px;

            }

        style>

    head>

    <body>

        <p class="myFirstClass mySecondClass">Параграф 1 p>

    body>

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

    Укажем несколько одинаковых свойств с разными значениями и посмотрим, какие из них будут применены к элементу:

    Одинаквые свойства CSS с разными значениями <style>

            .myFirstClass {

                background-color: darkcyan;

                color: darkgreen;

                font-size: 40px;

            }

            .mySecondClass {

                background-color: darkgrey;

                color: red;

                font-size: 20px;

            }

    style>

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

    <style>

    Очередность использования CSS классов         .mySecondClass {

                background-color: darkgrey;

                color: red;

                font-size: 20px;

            }

            .myFirstClass {

                background-color: darkcyan;

                color: darkgreen;

                font-size: 40px;

            }

        --style>

    Что касается порядка обьявления используемых классов в атрибуте class непосредвенно в самом теге, он не имеет значения:

    <p class="myFirstClass mySecondClass">Параграф 1p>

    <p class="mySecondClass myFirstClass">Параграф 1p>

    Эти две строки возымеют одинаковое воздействие на форматирование параграфа.

    КОМЕНТАРІ ТА ОБГОВОРЕННЯ
    advertisement advertisement

    Купуй передплатуз доступом до всіх курсів та сервісів

    Бібліотека сучасних IT знань у зручному форматі

    Вибирай свій варіант підписки залежно від завдань, що стоять перед тобою. Але якщо потрібно пройти повне навчання з нуля до рівня фахівця, краще вибирати Базовий або Преміум. А для того, щоб вивчити 2-3 нові технології, або повторити знання, готуючись до співбесіди, підійде Пакет Стартовий.

    Стартовий
    • Усі відеокурси на 3 місяці
    • Тестування з 10 курсів
    • Перевірка 5 домашніх завдань
    • Консультація з тренером 30 хв
    59.99 $
    Придбати
    Весняний
    • Усі відеокурси на 15 місяців
    • Тестування з 24 курсів
    • Перевірка 20 домашніх завдань
    • Консультація з тренером 120 хв
    90.00 $
    219.99 $
    Придбати
    Акція
    Преміум
    • Усі відеокурси на 12 місяців
    • Тестування з 24 курсів
    • Перевірка 20 домашніх завдань
    • Консультація з тренером 120 хв
    169.99 $
    Придбати
    Notification success