Стилизация вашего Angular-приложения

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

Необходимые условия: Понимание основ HTML, CSS, и JavaScript, знание терминала/командной строки
Цель: Изучить, как работать со стилями в Angular.

Добавление стилей

Angular CLI генерирует файлы стилей двух типов:

  • Стили компонентов: Angular CLI создает для каждого компонента файл с его стилями. Стили в этом файле применяются только к этому компоненту.
  • styles.css: В дирректории src, стили в этом файле применяются ко всему приложению, если не будут указаны стили на уровне компонента.

Если вы используете препроцессоры, расширение файлов со стилями может различаться. Кроме обычного CSS Angular поддерживает SCSS, Sass, Less и Stylus.

Вставьте в src/styles.css следующие стили:

css
body {
  font-family: Helvetica, Arial, sans-serif;
}

.btn-wrapper {
  /* flexbox */
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
}

.btn {
  color: #000;
  background-color: #fff;
  border: 2px solid #cecece;
  padding: 0.35rem 1rem 0.25rem 1rem;
  font-size: 1rem;
}

.btn:hover {
  background-color: #ecf2fd;
}

.btn:active {
  background-color: #d1e0fe;
}

.btn:focus {
  outline: none;
  border: black solid 2px;
}

.btn-primary {
  color: #fff;
  background-color: #000;
  width: 100%;
  padding: 0.75rem;
  font-size: 1.3rem;
  border: black solid 2px;
  margin: 1rem 0;
}

.btn-primary:hover {
  background-color: #444242;
}

.btn-primary:focus {
  color: #000;
  outline: none;
  border: #000 solid 2px;
  background-color: #d7ecff;
}

.btn-primary:active {
  background-color: #212020;
}

CSS в src/styles.css применяется ко всему приложению, но стилизует лишь некоторые элементы страницы. Дальше мы добавим стили конкретно для компонента AppComponent.

Для этого в app.component.css добавьте следующие стили:

css
body {
  color: #4d4d4d;
  background-color: #f5f5f5;
  color: #4d4d4d;
}

.main {
  max-width: 500px;
  width: 85%;
  margin: 2rem auto;
  padding: 1rem;
  text-align: center;
  box-shadow:
    0 2px 4px 0 rgba(0, 0, 0, 0.2),
    0 2.5rem 5rem 0 rgba(0, 0, 0, 0.1);
}

@media screen and (min-width: 600px) {
  .main {
    width: 70%;
  }
}

label {
  font-size: 1.5rem;
  font-weight: bold;
  display: block;
  padding-bottom: 1rem;
}

.lg-text-input {
  width: 100%;
  padding: 1rem;
  border: 2px solid #000;
  display: block;
  box-sizing: border-box;
  font-size: 1rem;
}

.btn-wrapper {
  margin-bottom: 2rem;
}

.btn-menu {
  flex-basis: 32%;
}

.active {
  color: green;
}

ul {
  padding-inline-start: 0;
}

ul li {
  list-style: none;
}

После можно вернуться в браузер и посмотреть, как обновились стили. Теперь все стало немного понятнее.

Резюме

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

В это модуле