CSS-префиксер для изоляции стилей: добавляем класс-обёртку ко всем правилам

При разработке крупных проектов или интеграции готовых UI-библиотек часто возникает проблема конфликта имён CSS-классов. Стили одной библиотеки могут неожиданно повлиять на элементы другой, даже если вы старались использовать уникальные имена. Обычно эту проблему решают через CSS Modules или Scoped CSS.

Существует и другой, менее очевидный подход: добавить единый класс-контейнер ко всем селекторам CSS-файла. Например, если все правила начинаются с .my-app, то они будут применяться только к элементам внутри блока с этим классом. Это эффективно изолирует стили, не требуя переписывания всей библиотеки.

В этой статье мы разберём PHP-скрипт, который автоматически добавляет заданный класс-префикс ко всем селекторам в CSS-файле. Такой инструмент может быть полезен, когда вы подключаете сторонний CSS (например, Materialize, Bootstrap) и хотите ограничить его действие определённой частью страницы.

Постановка задачи

Исходный CSS-файл (materialize.css) содержит селекторы разных типов:

Нужно получить файл, в котором каждый селектор (кроме тех, что внутри @keyframes, так как они не относятся к DOM-элементам) будет начинаться с указанного класса, например .mlds. При этом важно сохранить вложенность и медиа-правила:

Почему не Autoprefixer?

Созвучное название может внести путаницу. Autoprefixer добавляет вендорные префиксы к CSS-свойствам (-webkit--moz- и т.д.). Наша задача – изменить селекторы, а не свойства. Это позволяет создать неймспейс для целой библиотеки. Такой приём часто называют «css namespacing» или «scoping через родительский класс».

Обзор решения

Я буду использовать библиотеку sabberworm/php-css-parser, которая разбирает CSS в объектную модель, позволяет изменять узлы и затем рендерить обратно в строку. Скрипт:

  1. Загружает исходный CSS.
  2. Парсит его в дерево.
  3. Рекурсивно обходит все блоки правил (DeclarationBlock).
  4. Для каждого селектора добавляет перед ним префикс-класс и пробел.
  5. Пропускает @keyframes (их селекторы не нужно префиксировать).
  6. Сохраняет результат в новый файл.

Код с пояснениями

Я использую composer для подключения Sabberworm. Потому в начале файла появляется строка с vendor/autoload.php. Если вы подключаете Sabberworm напрямую, то у вас этот момент может отличаться.

input и output файлы определяют какой файл нужно править и куда потом сохранить правки.

Теперь в примере — достаточно обернуть часть страницы в <div class="mlds">, и стили Materialize будут действовать только внутри этого контейнера, не конфликтуя с остальными.

Ограничения и нюансы

  1. Сложные селекторы – скрипт просто добавляет пробел и класс в начало строки. Для селекторов вида div > .class + span это даст .mlds div > .class + span, что корректно.
  2. Селекторы с запятой – парсер библиотеки разбивает их на отдельные объекты, поэтому каждый получит префикс.
  3. :host и теневой DOM – если в CSS есть псевдоклассы для веб-компонентов, добавление класса может сломать логику. В таких случаях префиксация не рекомендуется.
  4. @keyframes не префиксируется – это осознанное решение. Если нужно изолировать имена анимаций, потребуется отдельный подход (переименование).
  5. Вес селекторов – добавление родительского класса увеличивает специфичность всех правил. Это редко приводит к проблемам, но о нюансе стоит помнить.

Мало букафф? Читайте есчо !

Верстка: большой блок слева и четыре малых справа

Март 15, 2025 г.

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

Читать

Кол-во знаков после запятой при генерации css препроцессором sass

Март 28, 2018 г.

В одном из проектов использовался SASS, но оказалось, что у другого разработчика другие настройки SASS. И конечные CSS генерировались с числами другой точности (другое кол-во знаков после запятой). Любое изменение в файле приводило к огромному ...

Читать

Анимация прокрутки в CSS: animation-timeline: scroll()

Сентябрь 1, 2025 г.

Ещё недавно для прогресс-бара чтения на сайте приходилось подключать JavaScript: отслеживать событие scroll, вычислять процент прокрутки и менять ширину элемента. Теперь это можно сделать чисто на CSS, благодаря новой возможности — Scroll-driven animations. ...

Читать

Переполнение текста (text-overflow)

Сентябрь 3, 2021 г.

Мы рассмотрим здесь как обрезать текст и добавить многоточие средствами CSS. Это еще одна классическая проблема фронт-енда, как не позволить тексту менять геометрию контейнера, если он не влазит целиком. CSS предоставляет специальное свойство для ...

Читать
 

Комментарии к «CSS-префиксер для изоляции стилей: добавляем класс-обёртку ко всем правилам»

Понравилась статья? Есть вопросы? - пишите в комментариях.



Комментарий: