Медиа-запросы: как настроить таргетинг на десктоп, планшет и мобильный телефон?

381

Я занимался некоторыми исследованиями в отношении медиа-запросов, и я до сих пор не совсем понимаю, как настроить таргетинг на устройства определенных размеров.

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

Некоторые примеры, которые я нашел:

# Mobile
only screen and (min-width: 480px)

# Tablet
only screen and (min-width: 768px) 

# Desktop
only screen and (min-width: 992px)

# Huge
only screen and (min-width: 1280px) 

Или:

# Phone
only screen and (max-width:320px)

# Tablet
only screen and (min-width:321px) and (max-width:768px)

# Desktop
only screen and (min-width:769px)

Как вы думаете, что эти "точки останова" должны быть для каждого устройства?

Показать ещё 1 комментарий
Теги:
mobile
media-queries
tablet

14 ответов

521
Лучший ответ

IMO - это лучшие точки останова:

@media (min-width:320px)  { /* smartphones, portrait iPhone, portrait 480x320 phones (Android) */ }
@media (min-width:480px)  { /* smartphones, Android phones, landscape iPhone */ }
@media (min-width:600px)  { /* portrait tablets, portrait iPad, e-readers (Nook/Kindle), landscape 800x480 phones (Android) */ }
@media (min-width:801px)  { /* tablet, landscape iPad, lo-res laptops ands desktops */ }
@media (min-width:1025px) { /* big landscape tablets, laptops, and desktops */ }
@media (min-width:1281px) { /* hi-res laptops and desktops */ }

Изменить: улучшено с 960 сетями:

@media (min-width:320px)  { /* smartphones, iPhone, portrait 480x320 phones */ }
@media (min-width:481px)  { /* portrait e-readers (Nook/Kindle), smaller tablets @ 600 or @ 640 wide. */ }
@media (min-width:641px)  { /* portrait tablets, portrait iPad, landscape e-readers, landscape 800x480 or 854x480 phones */ }
@media (min-width:961px)  { /* tablet, landscape iPad, lo-res laptops ands desktops */ }
@media (min-width:1025px) { /* big landscape tablets, laptops, and desktops */ }
@media (min-width:1281px) { /* hi-res laptops and desktops */ }

На практике многие дизайнеры конвертируют пиксели в ems, в основном b/c ems лучше обеспечивают масштабирование. При стандартном увеличении 1em === 16px. Умножьте пиксели на 1em/16px, чтобы получить ems. Например, 320px === 20em.

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

  • 1
    Мне было интересно увеличить нижний предел медиа-запросов. Кажется логичным, но не видел, чтобы это упоминалось слишком часто. Я бы даже сделал еще один шаг вперед и перешел на ems. Посмотрите на скриншоты @jonikorpi поведения Этана Маркотта с медиа-запросами масштабирования и px. github.com/scottjehl/Respond/issues/18
  • 16
    Почему вы используете минимальную ширину, а не максимальную ширину? Как бы вы предотвратили, чтобы min-width: 320px css переопределяло min-width: 801px ?
Показать ещё 13 комментариев
143

Если вы хотите настроить таргетинг на устройство, просто напишите min-device-width. Например:

Для iPhone

@media only screen and (min-device-width: 480px){}

Для планшетов

@media only screen and (min-device-width: 768px){}

Вот несколько хороших статей:

  • 22
    Мой планшет имеет ширину 2560х1600
  • 30
    Это может быть так, но браузеры на мобильных устройствах имеют «соотношение пикселей устройства». Здесь он обрабатывает каждый логический «пиксель» как 2, 3 или даже более фактических пикселей на вашем устройстве. В противном случае высота в 20 пикселей будет очень маленькой и ее невозможно будет нажать - особенно на вашем экране!
Показать ещё 7 комментариев
135

Не настраивайте таргетинг на определенные устройства или размеры!

общая мудрость не нацеливать определенные устройства или размеры, но перефразировать термин "точка останова":

  • сначала создайте сайт mobile first, используя проценты или ems, а не пиксели,
  • затем попробуйте в увеличенном окне просмотра и обратите внимание, где он начинает терпеть неудачу,
  • перепроектируйте макет и добавьте мультимедийный запрос CSS только для обработки сломанных частей,
  • повторите процесс, пока не достигнете следующей точки останова.

Вы можете использовать responsivepx.com, чтобы найти "естественные" точки останова, как в "точки останова мертвы" Марка Драммонда.

Использовать естественные точки останова

Затем "точки останова" становятся фактической точкой , когда ваш мобильный дизайн начинает "ломаться" , т.е. перестает быть полезным или визуально приятным. Когда у вас есть хороший рабочий мобильный сайт, без медиа-запросов, вы можете перестать беспокоиться о конкретных размерах и просто добавить медиа-запросы, которые обрабатывают последовательно большие видовые экраны.

Если вы не пытаетесь привязать дизайн к точному размеру экрана, этот подход работает , устраняя необходимость таргетинга на определенные устройства. целостность самого дизайна в каждой точке останова гарантирует, что он будет поддерживать любой размер. Другими словами, если раздел меню/содержимого/независимо от того, что его можно использовать при определенном размере, создайте точку останова для этого размера не для определенного размера устройства.

См. сообщение Лизы Гарднер в поведенческие точки останова, а также сообщение Зельдмана о Этане Маркоте и как развивался адаптивный веб-дизайн от идеи intitial.

  • 5
    Клиент захочет, чтобы его сайт выглядел так на iPad. Моя лучшая точка останова - заставить сайт переключиться на мобильную верстку на iPad. Клиент не согласится с этим, он хочет, чтобы на iPad и других планшетах появилась модная версия. Общая мудрость не платит мою зарплату :) Мне нужно было делать трюки с метатегом viewport. Это было очень больно, но я справился с небольшой помощью JavaScript (как всегда). PS: я использовал см единиц, а не пикселей.
  • 0
    С естественными точками останова вы можете иметь точку останова среднего размера, которая включает iPad (и другие планшеты) в ландшафтном режиме, или добавить другую точку останова для портретного режима. Иногда я использовал четыре точки останова, всегда запуская CSS и всю разметку с помощью mobile-first (сложнее уменьшить масштаб и сфокусировать внимание на мобильном, что означает, что ваш дизайн и контент сужены до базовых элементов, которые вы можете расширять по мере увеличения размеров) один чуть более 400 пикселей в ширину (или «выше мобильного размера»), затем два размера рабочего стола, один очень широкий. Затем вы можете настроить точку останова «над мобильным», чтобы она хорошо работала на iPad.
Показать ещё 7 комментариев
44
  1. Я использовал этот сайт, чтобы найти разрешение и разработал CSS для фактических чисел. Мои цифры немного отличаются от приведенных выше ответов, за исключением того, что мой CSS на самом деле попадает на нужные устройства.

  2. Кроме того, имейте этот отладочный фрагмент кода сразу после вашего медиа-запроса, например:

    @media only screen and (min-width: 769px) and (max-width: 1281px) { 
      /* for 10 inches tablet screens */
      body::before {
        content: "tablet to some desktop media query (769 > 1281) fired";
        font-weight: bold;
        display: block;
        text-align: center;
        background: rgba(255, 255, 0, 0.9); /* Semi-transparent yellow */
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        z-index: 99;
      }
    } 
    

    Добавьте этот элемент отладки в каждый медиазапрос, и вы увидите, какой запрос был применен.

23

Лучшие точки останова, рекомендованные Twitter Bootstrap

/* Custom, iPhone Retina */ 
    @media only screen and (min-width : 320px) {

    }

    /* Extra Small Devices, Phones */ 
    @media only screen and (min-width : 480px) {

    }

    /* Small Devices, Tablets */
    @media only screen and (min-width : 768px) {

    }

    /* Medium Devices, Desktops */
    @media only screen and (min-width : 992px) {

    }

    /* Large Devices, Wide Screens */
    @media only screen and (min-width : 1200px) {

    }
20

Запросы к мультимедиа для общих точек останова устройства

/* Smartphones (portrait and landscape) ----------- */
@media only screen and (min-device-width : 320px) and (max-device-width : 480px) {
/* Styles */
}

/* Smartphones (landscape) ----------- */
@media only screen and (min-width : 321px) {
/* Styles */
}

/* Smartphones (portrait) ----------- */
@media only screen and (max-width : 320px) {
/* Styles */
}

/* iPads (portrait and landscape) ----------- */
@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) {
/* Styles */
}

/* iPads (landscape) ----------- */
@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) and (orientation : landscape) {
/* Styles */
}

/* iPads (portrait) ----------- */
@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) and (orientation : portrait) {
/* Styles */
}
/**********
iPad 3
**********/
@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) and (orientation : landscape) and (-webkit-min-device-pixel-ratio : 2) {
/* Styles */
}

@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) and (orientation : portrait) and (-webkit-min-device-pixel-ratio : 2) {
/* Styles */
}
/* Desktops and laptops ----------- */
@media only screen  and (min-width : 1224px) {
/* Styles */
}

/* Large screens ----------- */
@media only screen  and (min-width : 1824px) {
/* Styles */
}

/* iPhone 4 ----------- */
@media only screen and (min-device-width : 320px) and (max-device-width : 480px) and (orientation : landscape) and (-webkit-min-device-pixel-ratio : 2) {
/* Styles */
}

@media only screen and (min-device-width : 320px) and (max-device-width : 480px) and (orientation : portrait) and (-webkit-min-device-pixel-ratio : 2) {
/* Styles */
}

/* iPhone 5 ----------- */
@media only screen and (min-device-width: 320px) and (max-device-height: 568px) and (orientation : landscape) and (-webkit-device-pixel-ratio: 2){
/* Styles */
}

@media only screen and (min-device-width: 320px) and (max-device-height: 568px) and (orientation : portrait) and (-webkit-device-pixel-ratio: 2){
/* Styles */
}

/* iPhone 6 ----------- */
@media only screen and (min-device-width: 375px) and (max-device-height: 667px) and (orientation : landscape) and (-webkit-device-pixel-ratio: 2){
/* Styles */
}

@media only screen and (min-device-width: 375px) and (max-device-height: 667px) and (orientation : portrait) and (-webkit-device-pixel-ratio: 2){
/* Styles */
}

/* iPhone 6+ ----------- */
@media only screen and (min-device-width: 414px) and (max-device-height: 736px) and (orientation : landscape) and (-webkit-device-pixel-ratio: 2){
/* Styles */
}

@media only screen and (min-device-width: 414px) and (max-device-height: 736px) and (orientation : portrait) and (-webkit-device-pixel-ratio: 2){
/* Styles */
}

/* Samsung Galaxy S3 ----------- */
@media only screen and (min-device-width: 320px) and (max-device-height: 640px) and (orientation : landscape) and (-webkit-device-pixel-ratio: 2){
/* Styles */
}

@media only screen and (min-device-width: 320px) and (max-device-height: 640px) and (orientation : portrait) and (-webkit-device-pixel-ratio: 2){
/* Styles */
}

/* Samsung Galaxy S4 ----------- */
@media only screen and (min-device-width: 320px) and (max-device-height: 640px) and (orientation : landscape) and (-webkit-device-pixel-ratio: 3){
/* Styles */
}

@media only screen and (min-device-width: 320px) and (max-device-height: 640px) and (orientation : portrait) and (-webkit-device-pixel-ratio: 3){
/* Styles */
}

/* Samsung Galaxy S5 ----------- */
@media only screen and (min-device-width: 360px) and (max-device-height: 640px) and (orientation : landscape) and (-webkit-device-pixel-ratio: 3){
/* Styles */
}

@media only screen and (min-device-width: 360px) and (max-device-height: 640px) and (orientation : portrait) and (-webkit-device-pixel-ratio: 3){
/* Styles */
}
18
  • Дополнительные небольшие устройства (телефоны, до 480 пикселей)
  • Маленькие устройства (планшеты, 768px и выше)
  • Средние устройства (большие планшеты для ландшафтов, ноутбуки и рабочих столов, 992px и выше).
  • Крупные устройства (большие рабочие столы, 1200 пикселей и выше)
  • портретные электронные книги (Nook/Kindle), меньшие таблетки - минимальная ширина: 481px
  • портретные планшеты, портрет iPad, пейзажные электронные книги - min-width: 641px
  • планшет, альбом iPad, ноутбуки с низким разрешением - min-width: 961px
  • HTC Одна ширина устройства: 360px device-height: 640px -webkit-device-pixel-ratio: 3
  • Samsung Galaxy S2 - ширина устройства: 320 пикселей: высота устройства: 534px -webkit-device-pixel-ratio: 1,5 (min-moz-device-pixel-ratio: 1.5), (-o-min-device-pixel -ratio: 3/2), (отношение min-device-pixel: 1,5
  • Samsung Galaxy S3 - ширина устройства: 320 пикселей. Высота устройства: 640 пикселей. -webkit-device-pixel-ratio: 2 (min - moz-device-pixel-ratio: 2), - Старые браузеры Firefox (до Firefox 16 ) -
  • Samsung Galaxy S4: ширина устройства: 320 пикселей. Высота устройства: 640 пикселей. -webkit-device-pixel-ratio: 3.
  • LG Nexus 4: ширина устройства: 384px Высота устройства: 592px -webkit-device-pixel-ratio: 2
  • Asus Nexus 7 - ширина устройства: 601px высота устройства: 906px -webkit-min-device-pixel-ratio: 1.331) и (-webkit-max-device-pixel-ratio: 1.332)
  • iPad 1 и 2, iPad Mini-ширина устройства: 768px высота устройства: 1024px -webkit-device-pixel-ratio: 1
  • IPad 3 и 4 ширина устройства: 768px высота устройства: 1024px -webkit-device-pixel-ratio: 2)
  • Размер устройства 3G для iPhone: 320 пикселей: высота устройства: 480 пикселей -webkit-device-pixel-ratio: 1)
  • iPhone 4: ширина устройства: 320 пикселей. Высота устройства: 480 пикселей. -webkit-device-pixel-ratio: 2)
  • Размер экрана устройства iPhone 5: 320px высота устройства: 568px -webkit-device-pixel-ratio: 2)
  • 1
    Sansung Galaxy S3 @media only screen и (device-width: 720px) и (device-height: 1280px) и (-webkit-min-device-pixel-ratio: 2) протестировали и работали.
5

Это не вопрос количества пикселей, это вопрос фактического размера (в мм или дюймах) символов на экране, который зависит от плотности пикселей. Следовательно, "min-width:" и "max-width:" бесполезны. Полное объяснение этой проблемы здесь: что такое коэффициент пикселей устройства?

Запросы

"@media" учитывают количество пикселей и соотношение пикселей устройства, что приводит к "виртуальному разрешению", которое необходимо учитывать при проектировании вашей страницы: если ваш шрифт имеет фиксированную ширину 10 пикселей и "виртуальное горизонтальное разрешение" составляет 300 пикселей, для заполнения строки потребуется 30 символов.

  • 5
    Отлично. Так какими должны быть медиа-запросы?
4

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

Самый простой способ сделать это - получить готовый дизайн рабочего стола и открыть его в веб-браузере. Медленно уменьшайте экран, чтобы сделать его уже. Наблюдайте, чтобы увидеть, когда дизайн начинает "ломаться" или выглядит ужасно и тесно. На этом этапе потребуется точка останова с медиа-запросом.

Распространено создание трех наборов медиа-запросов для рабочего стола, планшета и телефона. Но если ваш дизайн выглядит хорошо на всех трех, зачем беспокоиться о сложности добавления трех разных медиа-запросов, которые не нужны. Делайте это по мере необходимости!

2

В настоящее время наиболее распространенным явлением является просмотр устройств экрана сетчатки, другими словами: устройства с высоким разрешением и очень высокая плотность пикселей (но обычно размер меньше 6 дюймов). Для этого вам понадобятся специализированные медиа-запросы сетчатки на вашем CSS. Это самый полный пример, который я мог бы найти:

@media only screen and (min-width: 320px) {

  /* Small screen, non-retina */

}

@media
only screen and (-webkit-min-device-pixel-ratio: 2)      and (min-width: 320px),
only screen and (   min--moz-device-pixel-ratio: 2)      and (min-width: 320px),
only screen and (     -o-min-device-pixel-ratio: 2/1)    and (min-width: 320px),
only screen and (        min-device-pixel-ratio: 2)      and (min-width: 320px),
only screen and (                min-resolution: 192dpi) and (min-width: 320px),
only screen and (                min-resolution: 2dppx)  and (min-width: 320px) { 

  /* Small screen, retina, stuff to override above media query */

}

@media only screen and (min-width: 700px) {

  /* Medium screen, non-retina */

}

@media
only screen and (-webkit-min-device-pixel-ratio: 2)      and (min-width: 700px),
only screen and (   min--moz-device-pixel-ratio: 2)      and (min-width: 700px),
only screen and (     -o-min-device-pixel-ratio: 2/1)    and (min-width: 700px),
only screen and (        min-device-pixel-ratio: 2)      and (min-width: 700px),
only screen and (                min-resolution: 192dpi) and (min-width: 700px),
only screen and (                min-resolution: 2dppx)  and (min-width: 700px) { 

  /* Medium screen, retina, stuff to override above media query */

}

@media only screen and (min-width: 1300px) {

  /* Large screen, non-retina */

}

@media
only screen and (-webkit-min-device-pixel-ratio: 2)      and (min-width: 1300px),
only screen and (   min--moz-device-pixel-ratio: 2)      and (min-width: 1300px),
only screen and (     -o-min-device-pixel-ratio: 2/1)    and (min-width: 1300px),
only screen and (        min-device-pixel-ratio: 2)      and (min-width: 1300px),
only screen and (                min-resolution: 192dpi) and (min-width: 1300px),
only screen and (                min-resolution: 2dppx)  and (min-width: 1300px) { 

  /* Large screen, retina, stuff to override above media query */

}

Источник: Сайт CSS-Tricks

2

Поведение не меняется на рабочем столе. Но на планшетах и мобильных телефонах я расширяю панель навигации, чтобы охватить большое изображение логотипа. Примечание. Используйте поля (верх и низ) столько, сколько вам нужно для высоты вашего логотипа.

Для моего случая 60px top и bottom работали отлично!

@media (max-width:768px) { 
  .navbar-toggle {
      margin: 60px 0;
  }
}

Проверьте навигационную панель здесь.

0

Еще одна особенность - вы также можете использовать медиа-запросы в медиа- атрибуте <link>.

<link href="/style.css" rel="stylesheet">
<link href="/justForFrint.css" rel="stylesheet" media="print">
<link href="/deviceSizeDepending.css" rel="stylesheet" media="(min-width: 40em)">

При этом браузер загрузит все CSS-ресурсы независимо от атрибута media. Разница в том, что если media-запрос атрибута media оценивается как false, то этот файл .css и его содержимое не будут блокировать рендеринг.

Поэтому рекомендуется использовать атрибут media в <link> поскольку он гарантирует лучшее взаимодействие с пользователем.

Здесь вы можете прочитать статью Google об этой проблеме https://developers.google.com/web/fundamentals/performance/critical-rendering-path/render-blocking-css.

Некоторые инструменты, которые помогут вам автоматизировать разделение кода CSS в разных файлах в соответствии с вашими медиа-запросами.

Webpack https://www.npmjs.com/package/media-query-plugin https://www.npmjs.com/package/media-query-splitting-plugin

PostCSS https://www.npmjs.com/package/postcss-extract-media-query

0
  • Очень маленькие устройства ~ телефоны (<768 пикселей)
  • Маленькие устройства ~ планшеты (> = 768 пикселей)
  • Средние устройства ~ десктопы (> = 992px)
  • Большие устройства ~ десктопы (> = 1200 пикселей)
-2
@media (max-width: 767px)   {

      .container{width:100%} *{color:green;}-Mobile

    }


    @media (min-width: 768px)  {

     .container{width:100%} *{color:pink  } -Desktop

    }
    @media (min-width: 768px) and (orientation:portrait)  {

       .container{width:100%} *{color:yellow  } -Mobile

    }
    @media (min-width: 1024px)  {

       .container{width:100%} *{color:pink  } -Desktop

    }
    @media (min-width: 1200px)  {

    .container{width:1180px} *{color:pink   } -Desktop

    }

Ещё вопросы

Сообщество Overcoder
Наверх
Меню