Стилизация вашего Angular-приложения
Теперь, когда мы создали базовую структуру приложения и начали отображать что-то полезное, давайте переключимся и рассмотрим статью, посвященную тому, как Angular работает со стилями.
Необходимые условия: | Понимание основ HTML, CSS, и JavaScript, знание терминала/командной строки |
---|---|
Цель: | Изучить, как работать со стилями в Angular. |
Добавление стилей
Angular CLI генерирует файлы стилей двух типов:
- Стили компонентов: Angular CLI создает для каждого компонента файл с его стилями. Стили в этом файле применяются только к этому компоненту.
styles.css
: В дирректорииsrc
, стили в этом файле применяются ко всему приложению, если не будут указаны стили на уровне компонента.
Если вы используете препроцессоры, расширение файлов со стилями может различаться. Кроме обычного CSS Angular поддерживает SCSS, Sass, Less и Stylus.
Вставьте в src/styles.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
добавьте следующие стили:
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;
}
После можно вернуться в браузер и посмотреть, как обновились стили. Теперь все стало немного понятнее.
Резюме
В это модуле
-
React
-
Ember
-
Vue
- Начало работы с Vue
- Создание вашего первого компонента Vue
- Отрисовка списка Vue компонентов
- Добавление новой формы во Vue: события, методы, и модели
- Стилизация Vue компонентов с CSS
- Использование вычисляемых свойств во Vue
- Условная отрисовка во Vue: Редактирование существующих дел
- Управление фокусом во Vue с помощью refs
- Ресурсы по Vue
-
Svelte
- Начало работы со Svelte
- Начинаем приложение списка дел c использованием Svelte
- Динамическое поведение в Svelte: работа с переменными и пропсами
- Компоненты Svelte приложения
- Продвинутый Svelte: реактивность, жизненный цикл, доступность
- Работа хранилищами в Svelte
- Поддержка TypeScript в Svelte
- Развертывание и следующие шаги
-
Angular