Как сделать адаптивные изображения?

284
01 апреля 2017, 00:35

Подскажите вариант, как сделать адаптивные изображения?

Что хочется:

  1. Под каждый breakpoint грузится свое изображение
  2. Учитывается изображение для retina дисплеев
  3. Изображения масштабируются
Answer 1

Можно воспользоваться атрибутом srcset (HTML5)

Атрибут может использоваться вместо src и позволяет задавать различные URL изображений. Значением атрибута является одна или несколько строк, разделенных запятой. В состав каждой строки входят:

  1. URL файла с изображением
  2. optionally, whitespace followed by one of:

    -- значение ширины viewport (им должно быть положительное целое число, за которым следует символ «w»). The width descriptor is divided by the source size given in the sizes attribute to calculate the effective pixel density.
    -- значение плотности пикселей (положительное число, за которым следует символ «x»), по умолчанию равно 1x.

Можно через медиазапрос + :after + background-image.

Answer 2

Для создания максимально адаптивных изображений подходит конструкция

<picture>
  <source media="(media-query-1)" sizes="(media-query-1.1) x, y" srcset="images/ordinary.jpg">
  <source media="(media-query-2)" sizes="(media-query-2.1) z, w" srcset="images/ordinary-2.jpg">
  <img src="images/ordinary.jpg">
</picture>
  1. Допустим, вы хотите, чтобы на экранах до 400 пикселей было одно изображение, а на экранах больше другое. Делаем так:
<picture>
  <source media="(max-width: 400px)" srcset="images/ordinary.jpg">
  <source media="(min-width: 401px)" srcset="images/ordinary2.jpg">
  <img src="images/ordinary2.jpg">
</picture>
  1. Также вы хотите, чтобы принималась в учет плотность пикселей. Тогда необходимо в атрибуте srcset указывать несколько путей изображений, через пробел писать 1x, 2x и, если необходимо, то и 3x. x позволяет обратиться к device-pixel-ratio.
<picture>
  <source media="(max-width: 400px)" srcset="images/ordinary.jpg 1x, images/ordinary-retina.jpg 2x, images/ordinary-hd.jpg 3x">
  <source media="(min-width: 401px)" srcset="images/ordinary2.jpg 1x, images/ordinary2-retina.jpg 2x, images/ordinary2-hd.jpg 3x">
  <img src="images/ordinary2.jpg">
</picture>
  1. Также вы хотите для разных брейкпоинтов разный размер изображения, тут придет на выручку атрибут sizes. У нас будет реализовываться следующий сценарий: 1) для экранов меньше 800 пикселей будет изображение ordinary.jpg, 1.1) для экранов 400 и меньше пикселей изображение будет иметь ширину 100vw, в остальных случаях оно будет занимать 70vw; 2) для экранов больше 800 пикселей ordinary2.jpg, 2.2) для экранов больше 1400 пикселей у него будет ширина 40vw, в остальных случаях 50vw.
<picture>
  <source media="(max-width: 800px)" sizes="(max-width: 400px) 100vw, 50vw" srcset="images/ordinary.jpg 1x, images/ordinary-retina.jpg 2x, images/ordinary-hd.jpg 3x">
  <source media="(min-width: 801px)" sizes="(min-width: 1400px) 40vw, 50vw" srcset="images/ordinary2.jpg 1x, images/ordinary2-retina.jpg 2x, images/ordinary2-hd.jpg 3x">
  <img src="images/ordinary2.jpg">
</picture>
READ ALSO
Как изменить значение атрибута value в теге input?

Как изменить значение атрибута value в теге input?

Необходимо менять значение именно используя Javascript, тк

221
Проблема с созданием пакета для Salesforce.com

Проблема с созданием пакета для Salesforce.com

Всем доброго дня! Я разрабатываю интеграцию сервиса телефонии Zadarma с облачной CRM Salesforce при помощи OpenCTIАккаунт разработчика создан, Force

222
как открыть новое окно без рамки?

как открыть новое окно без рамки?

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

255