1 added
1 removed
Original
2026-01-01
Modified
2026-02-26
1
<p>На первых этапах препроцессоры удобно рассматривать с точки зрения расширения стандартных возможностей CSS. Эти возможности помогают лучше структурировать ваш код в файле и сократить количество повторений классов.</p>
1
<p>На первых этапах препроцессоры удобно рассматривать с точки зрения расширения стандартных возможностей CSS. Эти возможности помогают лучше структурировать ваш код в файле и сократить количество повторений классов.</p>
2
<h2>Вложенность</h2>
2
<h2>Вложенность</h2>
3
<p>Первой возможностью, с помощью которой можно расширить CSS, является<strong>вложенность правил</strong>. Это позволяет писать связанный CSS-код в одном месте, внутри одного селектора. Такой подход упрощает понимание CSS, ведь теперь мы будем всегда чётко видеть связь элементов и всё это будет находиться в одном месте.</p>
3
<p>Первой возможностью, с помощью которой можно расширить CSS, является<strong>вложенность правил</strong>. Это позволяет писать связанный CSS-код в одном месте, внутри одного селектора. Такой подход упрощает понимание CSS, ведь теперь мы будем всегда чётко видеть связь элементов и всё это будет находиться в одном месте.</p>
4
<p>Можно увидеть, что селекторы<em>.logo</em>и<em>.company-name</em>находятся внутри селектора<em>.header</em>. Что же это будет обозначать и во что скомпилируется данный код? Препроцессор<em>SASS</em>возьмёт правила селектора<em>.header</em>и оставит их без изменений, а вот для<em>.logo</em>и<em>.company-name</em>будет подставлен родительский селектор, то есть<em>.header</em>. На выходе мы получим следующий CSS:</p>
4
<p>Можно увидеть, что селекторы<em>.logo</em>и<em>.company-name</em>находятся внутри селектора<em>.header</em>. Что же это будет обозначать и во что скомпилируется данный код? Препроцессор<em>SASS</em>возьмёт правила селектора<em>.header</em>и оставит их без изменений, а вот для<em>.logo</em>и<em>.company-name</em>будет подставлен родительский селектор, то есть<em>.header</em>. На выходе мы получим следующий CSS:</p>
5
<p>Такой подход помогает в объёмных макетах, и позволяет избежать постоянного повторения родительского селектора. Согласитесь, что это очень удобно и не даёт "прозевать" указание родительского селектора.</p>
5
<p>Такой подход помогает в объёмных макетах, и позволяет избежать постоянного повторения родительского селектора. Согласитесь, что это очень удобно и не даёт "прозевать" указание родительского селектора.</p>
6
<p>Но будьте аккуратны. Использование селекторов повышает специфичность, так как теперь стили для класса<em>.company-name</em>выполнятся только при наличии родительского блока с классом<em>.header</em>. Такая специфичность зачастую вредит нормальному использованию<em>CSS</em>, поэтому всегда необходимо отдавать себе отчёт в том, нужно ли вводить такую вложенность.</p>
6
<p>Но будьте аккуратны. Использование селекторов повышает специфичность, так как теперь стили для класса<em>.company-name</em>выполнятся только при наличии родительского блока с классом<em>.header</em>. Такая специфичность зачастую вредит нормальному использованию<em>CSS</em>, поэтому всегда необходимо отдавать себе отчёт в том, нужно ли вводить такую вложенность.</p>
7
<p>То же самое касается и уровней вложенности.<em>SASS</em>не запретит вам бесконечно вкладывать селекторы друг в друга. Но в конечном итоге не только сделает правила максимально специфичными, но и раздует их до такой степени, что их нельзя будет понять.</p>
7
<p>То же самое касается и уровней вложенности.<em>SASS</em>не запретит вам бесконечно вкладывать селекторы друг в друга. Но в конечном итоге не только сделает правила максимально специфичными, но и раздует их до такой степени, что их нельзя будет понять.</p>
8
<h2>Суффиксы</h2>
8
<h2>Суффиксы</h2>
9
<p>Не менее полезная возможность -<strong>суффиксы</strong>. Возьмём простой пример: мы пишем небольшой CSS-файл с модулем flex. Стили можно обозначить следующим образом:</p>
9
<p>Не менее полезная возможность -<strong>суффиксы</strong>. Возьмём простой пример: мы пишем небольшой CSS-файл с модулем flex. Стили можно обозначить следующим образом:</p>
10
<p>Эти стили позволяют нам установить свойства<em>display</em>,<em>justify-content</em>и<em>align-items</em>. Причём последние два свойства зависят от свойства<em>display</em>. Если не указан класс<em>flex</em>, то выравнивание по осям не будет работать.</p>
10
<p>Эти стили позволяют нам установить свойства<em>display</em>,<em>justify-content</em>и<em>align-items</em>. Причём последние два свойства зависят от свойства<em>display</em>. Если не указан класс<em>flex</em>, то выравнивание по осям не будет работать.</p>
11
<p>В данном виде кажется, что проблем нет. Но если вы создаёте такие стили для каждого класса, то количество правил только растёт. Скорее всего они будут раскиданы по всему файлу, что неудобно при последующем редактировании.</p>
11
<p>В данном виде кажется, что проблем нет. Но если вы создаёте такие стили для каждого класса, то количество правил только растёт. Скорее всего они будут раскиданы по всему файлу, что неудобно при последующем редактировании.</p>
12
<p><em>SASS</em>позволяет вкладывать такие свойства внутрь друг друга. Так как главным классом здесь является<em>flex</em>, то все остальные можно расположить внутри него. Чтобы проверять наличие именно двух классов, используется суффикс<strong>&</strong>.</p>
12
<p><em>SASS</em>позволяет вкладывать такие свойства внутрь друг друга. Так как главным классом здесь является<em>flex</em>, то все остальные можно расположить внутри него. Чтобы проверять наличие именно двух классов, используется суффикс<strong>&</strong>.</p>
13
<p>Другим удобным примером использования суффиксов является наличие псевдоклассов, например<em>:hover</em>.</p>
13
<p>Другим удобным примером использования суффиксов является наличие псевдоклассов, например<em>:hover</em>.</p>
14
<p><strong>SCSS</strong></p>
14
<p><strong>SCSS</strong></p>
15
<p><strong>CSS</strong></p>
15
<p><strong>CSS</strong></p>
16
<h2>Комбинирование</h2>
16
<h2>Комбинирование</h2>
17
-
<p>Вы можете свободно комбинировать оба подхода для написания аккуратного CSS, в котором появится возможность не запутаться. Представим ситуацию: нам необходимо создать блок со ссылкой, внутри которой находится картинка. Картинка по умолчанию скрыта. При наведении на эту ссылку картинка должна появляться, а текст внутри ссылки должен становиться насыщенным. Для большей убедительности мы имеем только один класс, обрамляющий ссылку. Решим эту задачу с помощью обычного CSS:</p>
17
+
<p>Вы можете свободно комбинировать оба подхода для написания аккуратного CSS, в котором появится возможность не запутаться. Представим ситуацию: нам необходимо создать блок со ссылкой, внутри которой находится картинка. Картинка по умолчанию скрыта. При наведении на эту ссылку картинка должна появляться, а текст внутри ссылки должен стан��виться насыщенным. Для большей убедительности мы имеем только один класс, обрамляющий ссылку. Решим эту задачу с помощью обычного CSS:</p>
18
<p>Теперь представьте, что это большой проект, где стилей для этих классов будет раза в два больше. Не очень удобная картина получается. Особенно учитывая то, что разработчики не всегда следят за логикой происходящего и стили могут стоять в разном порядке и даже в разных местах кода. Препроцессоры помогут решить эту проблему. С использованием<em>SASS</em>стили будут выглядеть следующим образом:</p>
18
<p>Теперь представьте, что это большой проект, где стилей для этих классов будет раза в два больше. Не очень удобная картина получается. Особенно учитывая то, что разработчики не всегда следят за логикой происходящего и стили могут стоять в разном порядке и даже в разных местах кода. Препроцессоры помогут решить эту проблему. С использованием<em>SASS</em>стили будут выглядеть следующим образом:</p>
19
<p>Может мы и не уменьшили количество строк в файле, но теперь все стили лежат так, что с ними удобно работать и мы избежали повторения написания родительских селекторов. Это экономит кучу времени и позволяет избежать многих ошибок.</p>
19
<p>Может мы и не уменьшили количество строк в файле, но теперь все стили лежат так, что с ними удобно работать и мы избежали повторения написания родительских селекторов. Это экономит кучу времени и позволяет избежать многих ошибок.</p>