mediazapiti

Медіазапити

  • Це інструмент, який робить можливим створення сучасних адаптивних веб-сторінок, які однаково добре виглядають на будь-якому екрані: десктопі або смартфоні.

Робота з медіазапитами зводиться до застосування того чи іншого 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-правил, які потрібно застосувати до документа,
    якщо умова перевірки медіатипу та виразу істинна
  */
}

Фонові зображення під ретіна-дісплей (у CSS)

  1. Викачуємо зораження під кожен розмір єкрана
  2. В backround-image в css під кжен медіа-запит вказуємо шлях до кожного розміру
  3. Потім викачуємо під кожен розмір дисплею 2х і додаємо картинку (для retina-єкранів)

Контектні зображення під ретіна-дісплей (у HTML)

  1. Викачуємо зораження під кожен розмір 2x єкрана
  2. у тегу imgпере src додаємо
<img
srcset="./image1.jpg 1x,
./image1.jpg 2x"

src="./original.jpg" />

Кадрування зобрження для різних єкранів

  1. викачуємо 1х під кожен єкран
  2. викачуємо 2х під кожен єкран
  3. викорустужмо код
<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>

Підхід «Mobile First»

вимагає починати створення сайту із мобільної версії. Давай з’ясуємо переваги цього підходу.

selector {
  /* Базові стилі */
}

@media (min-width: ширина-планшета) {
  selector {
    /* Стилі планшета */
  }
}

@media (min-width: ширина-десктопа) {
  selector {
    /* Стилі робочого столу */
  }
}

Рекомендації

При формуванні у «Mobile First»

  1. Спочатку робимо макет для ширини 320px
  2. потім описуємо першу реперну точку медіа-запиту з макету (наприклад для min-width: 380px)
  3. кожну наступну реперну точку під попередньою описуємо (каскад стилів)

Додаємо всередині кожного медіа-запиту ще один вкладенний запит

@media (min-resolution: 192dpi) {
  .box {
    background-image: url("https://picsum.photos/id/237/640/480");
  }
}
  • /sites/data/pages/mediazapiti.txt
  • Последнее изменение: 2023/10/12 18:01
  • tro