Робота з медіазапитами зводиться до застосування того чи іншого CSS-правила. Вибір та використання певного CSS-правила залежить від таких факторів, як розмір вікна браузера (області перегляду, в’юпорта), налаштування браузера, можливості пристрою і т.д.
@media screen and (min-width: 900px) {
body {
background-color: orange;
}
}
визначає мінімальну ширину області перегляду. У разі, якщо екран відповідає значенню в min-width, будуть застосовані вкладені CSS-правила.
визначає максимальну ширину в'юпорта, до якої включно будуть застосовуватися вкладені CSS-правила.
визначити стилі, що будуть застосовані при відправці на друк. Друк може виконуватися на фізичному принтері або віртуально.
@media print {
body {
color: green;
}
}
Якщо не вказати тип носія, за замовчуванням буде використано значення all. Воно означає будь-який пристрій. </code>
визначає стилі, що будуть застосовані тільки для пристроїв з фізичним екраном: смартфони, планшети, монітори, телевізори тощо.
@media (min-width: 400px) {
/* ... */
}
Медіазапити підтримують логічні оператори and, or, not, Ці оператори подібні до тих, які використовуються в математиці, логіці або мовах програмування. Якщо оператор не вказано, використовується значення за замовчуванням — only.
@media only|not media-type ****only|and|not ****(media-feature) {
/*
Набір CSS-правил, які потрібно застосувати до документа,
якщо умова перевірки медіатипу та виразу істинна
*/
}
<img srcset="./image1.jpg 1x, ./image1.jpg 2x" src="./original.jpg" />
<picture> <source srcset="./img1-destop.jpg 1x, img1-destop.jpg 2x" media="(min-width: 1166px)"> <source srcset="./img1-tablet.jpg 1x, img1-tablet.jpg 2x" media="(min-width: 768px)> <source srcset="./img1-mobile.jpg 1x, img1-mobile.jpg 2x" media="(max-width: 767px)> <img src "./img1-tablet.jpg" alt="dsdgd"> </picture>
вимагає починати створення сайту із мобільної версії. Давай з’ясуємо переваги цього підходу.
selector {
/* Базові стилі */
}
@media (min-width: ширина-планшета) {
selector {
/* Стилі планшета */
}
}
@media (min-width: ширина-десктопа) {
selector {
/* Стилі робочого столу */
}
}
При формуванні у «Mobile First»
Додаємо всередині кожного медіа-запиту ще один вкладенний запит
@media (min-resolution: 192dpi) {
.box {
background-image: url("https://picsum.photos/id/237/640/480");
}
}