3 совета по управлению стилями в CSS приложения Angular

3 совета по управлению стилями в CSS приложения Angular

От автора: посмотрим правде в глаза: когда мы работаем над интерфейсом, написание CSS — это не то, что нас больше всего волнует. Нам нравится возиться с более серьезными вещами (вы понимаете, о чем я — JavaScript). Большинство приложений, с которыми я сталкивался, и я уверен, что вы тоже, имеют большой беспорядок в области таблицы стилей. Такие проблемы, как дублирование кода, переопределение стилей, отсутствие организации и т. д. — обычная вещь.

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

Создание библиотеки основных компонентов

В каждом приложении существует единый стиль. Это может быть отражено в стилях полей ввода, кнопок, вкладок, всплывающих подсказок и т. д. Поэтому я рекомендую написать библиотеку основных компонентов на основе руководства по стилю приложения. Преимущества такой библиотеки — наличие единого источника достоверной информации о стиле и поведении компонентов, а также более быстрые циклы разработки, особенно по мере того, как приложение становится больше и сложнее. Например:

<button appButton>Click</button>
<app-select [options]="[]"></app-select>
<app-accordion>....</app-accordion>

Такую библиотеку можно построить двумя способами; в случае, если приложение уже велико, и у нас есть большое количество компонентов, рекомендуется создать специальную команду, которая будет ее создавать.

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

Используйте служебные классы

Теперь, когда у нас есть библиотека, которая предоставляет нам все компоненты, необходимые для создания новой функции, нам нужно заняться более мелкими вещами. Например, стилизация отображения элементов с помощью flexbox или сетки, добавление полей, отступов и т. д. Чтобы справиться с этим, я рекомендую использовать подход служебных классов — он и быстрый, и чистый. В своих проектах я использую библиотеку CSS Tailwind.

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

Давайте добавим Tailwind в наш проект, используя еще одну аккуратную библиотеку от ngneat. Эта схема добавит CSS Tailwind в приложение Angular.

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

<div class="flex justify-between"> <div class="mr-4"> ... </div>
</div>

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

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

Я настоятельно рекомендую изучить Tailwind, так как у него много возможностей. Если вы работаете с VSCode, вы можете использовать этот отличный плагин для IntelliSense:

Или используйте этот плагин для быстрого доступа к документации:

В Webstorm вы также получите автозаполнение из коробки.

Используйте переменные CSS

Я хочу закончить небольшим, но важным советом — используйте переменные CSS. Применяйте их для определения цветов, размеров и любых других значений, которые многократно используются в приложении. Они широко поддерживаются, могут быть изменены во время выполнения и могут быть ограничены элементом.

Например, посмотрите, как легко вы можете создать темный режим для своего приложения:

:root { --font-family: Helvetica, Arial, Sans-Serif;
} body { --primary-100: #fff; --primary-200: #9f1f12;
} body.dark-theme { --primary-100: #000; --primary-200: #f2f2f2;
} body { background-color: var(--primary-100); color: var(--primary-200); font-family: var(--font-family);
}

Теперь единственное, что нам нужно сделать, это переключить класс dark-theme.

Если вы это пропустили

Вот несколько моих проектов с открытым исходным кодом:

Akita: управление состоянием, специально разработанное для приложений JS

Spectator: мощный инструмент для упрощения тестов Angular

Transloco: библиотека интернационализации Angular

Forms Manager: Foundation для Proper Form Management в Angular

Cashew: гибкая и простая библиотека, которая кэширует HTTP-запросы.

Error Tailor: бесшовные формы ошибок для приложений Angular

Автор: Netanel Basal

Источник: https://netbasal.com

Редакция: Команда webformyself.