Вёрстка (HTML/CSS) - адаптивная вёрстка
Адаптивная вёрстка предполагает отсутствие горизонтальной полосы прокрутки и
масштабируемых областей при просмотре на любом устройстве, читабельный текст и
большие области для кликабельных элементов. С помощью медиазапросов можно
управлять компоновкой и расположением блоков на странице, перестраивая шаблон
таким образом, чтобы он адаптировался под разные размеры экранов устройств.
1 Принципы адаптивного дизайна:
- гибкость макета базируется на использовании относительных единиц измерения
вместо фиксированных пиксельных значений, что позволяет регулировать ширину
в соответствии с доступным пространством;
- гибкость текстового содержимого достигается путем вычисления размеров шрифта
относительно размера шрифта;
- проблема гибких изображений решается с помощью правила img {width: 100%;
max-width: 100%;} для всех картинок на сайте. Это правило гарантирует, что
изображения никогда не будут шире, чем их контейнеры и никогда не превысят
своих истинных размеров на больших экранах;
- медиазапросы изменяют стили на основании характеристик устройства, связанных
с отображением контента, включая тип, ширину, высоту, ориентацию и
разрешение экрана. С помощью медиазапросов создается отзывчивый дизайн, в
котором к каждому размеру экрана применяются подходящие стили.
2 Дополнительные приёмы:
- масштабируемая векторная графика — используйте svg-изображения, которые
масштабируются до любого размера без потери качества и хорошо выглядят на
дисплеях Retina;
- оставьте самое необходимое — расставьте приоритеты и правильно скройте
контент — используйте скрытые элементы управления, особенно для устройств с
небольшими экранами. Всплывающие окна, табы, off-canvas меню и другие
подобные приёмы помогут уменьшить количество элементов на странице;
- большое кликабельное пространство для кнопок — чем больше активная область
кнопки, тем легче пользователю взаимодействовать с ней;
- добавьте интерактивности в свои интерфейсы — в ответ на действие
пользователя создайте ответное действие — анимацию, которая будет работать
при наведении на элемент на десктопных устройствах и при прикосновении к
элементу на мобильных устройствах.
3 Мета-тег viewport:
Чтобы мобильные браузеры не изменяли автоматически размер страниц сайта,
используется специальный тег <meta\
с атрибутом name="viewport". В данном теге
допускается устанавливать определенное значение для параметров width
и
initial-scale
:
<meta name="viewport" content="width=device-width, initial-scale=1">
width
указывает размер CSS-пикселя. При значении device-width
, ширина страницы равна ширине
экрана устройства с поправкой на плотность пикселей на экране, так как фактический пиксель
на смартфонах обычно меньше пикселя на экранах компьютеров и ноутбуков;
При числовом значении CSS-пиксель будет такого размера, что бы на экран помещалось
это количество пикселей. (меньше число - крупнее шрифты и т. п.)
initial-scale
- изначальное масштабирование. Так же есть параметры minimal-scale
и
maximum-scale
для задания ограничений масштаба страницы.
4 «Контрольные» точки:
Обычно «контрольные» точки имеют 4 варианта в зависимости от ширины экрана:
- 320px (375px) – 767px (мобильные устройства);
- 768px – 1023px (планшеты);
- 1024px – 1199px (десктопы);
- 1200px – … («большие» десктопы).
5 Медиа-запросы:
В общем случае медиа-запрос состоит из ключевого слова, описывающего тип
устройства (необязательный параметр) и выражения, проверяющего характеристики
данного устройства. Из всех характеристик чаще всего проверяется ширина
устройства width. Медиа-запрос является логическим выражением, которое
возвращает истину или ложь.
Медиа-запросы могут быть добавлены следующими способами:
- непосредственно в коде страницы:
<style>
@media (max-width: 767px) { #sidebar {display: none;} }
</style>
- внутри таблицы стилей main.css:
@media (max-width: 767px) { #sidebar {display: none;} }
- Так же вы может указывать медиа запросы при подключении css-файла в тэге
<link>
:
<link rel="stylesheet" media="screen and (max-width: 600px)" href="small.css"/>
<link rel="stylesheet" media="screen and (min-width: 600px)" href="large.css"/>
<link rel="stylesheet" media="print" href="print.css"/>
6 Логические операторы:
- оператор and связывает друг с другом разные условия:
@media screen and (max-width: 600px) {/* CSS-стили */;}
- оператор not позволяет сработать медиазапросу в противоположном случае.
Ключевое слово not добавляется в начало медиазапроса и применяется ко всему
запросу целиком, т.е. запрос:
@media not all and (monochrome) {...}
сработает как not (all and monochrome)
не (все виды вывода и чб)
7 Тип носителя:
Тип носителя представляет собой тип устройства, например, принтеры, экраны.
- all - подходит для всех типов устройств;
- print - предназначен для страничных материалов и документов
просматриваемых на экране в режиме предварительного просмотра печати;
- screen - предназначен в первую очередь для экранов цветных компьютерных
мониторов;
- speech - предназначен для синтезаторов речи.
8 Характеристики носителя:
К характеристикам медианосителя относятся проверяемые параметры устройства.
Значения, которые используются при задании характеристик, являются контрольными
точками.
- width - проверяет ширину области просмотра. Значения задаются в единицах
длины, px, em и т.д., например, (width: 800px). Обычно для проверки
используются минимальные и максимальные значения ширины. min-width применяет
правило если ширина области просмотра больше значения, указанного в запросе,
max-width — ширина области просмотра меньше значения, указанного в запросе;
- height- проверяет высоту области просмотра. Значения задаются в
единицах длины, px, em и т.д., например, (height: 500px). Обычно для
проверки используются минимальные и максимальные значения высоты. min-height
применяет правило если высота области просмотра больше значения, указанного
в запросе, max-height — высота области просмотра которого меньше значения,
указанного в запросе.
примерчик