Почему тега img недостаточно для современных веб-приложений?
Все эти вопросы можно сгруппировать в две большие категории:
- Смена разрешения — проблема передачи изображений меньшего размера для устройств с маленькими экранами.
- Ориентация графики — проблема отображения различных изображений при разных размерах экрана.
Давайте посмотрим, как решаются эти проблемы и узнаем о дополнительных возможностях тега picture
.
Смена разрешения при помощи атрибутов srcset
и sizes
Как говорилось выше, современные веб-дизайнеры для привлечения пользователей часто используют изображения высокого разрешения. Но мы, разработчики, должны внимательно выбирать подходящий HTML-элемент.
Допустим, вы используете простой тег Img
для изображений высокого разрешения. В таком случае при запуске приложения одно и то же изображение будет использоваться на каждом устройстве, что приведёт к проблемам с производительностью в устройствах с низким разрешением экрана, например, в мобильных телефонах.
Это может привести к более долгой загрузке изображений и частичной загрузке изображений сверху вниз.
Эту проблему можно легко решить тегом picture
при помощи атрибутов srcset
и sizes
.
<picture>
<source
srcset="small-car-image.jpg 400w,
medium-car-image.jpg 800w,
large-car-image.jpg 1200w"
sizes="(min-width: 1280px) 1200px,
(min-width: 768px) 400px,
100vw">
<img src="medium-car-image.jpg" alt="Car">
</picture>
Атрибут srcset
может принимать несколько изображений с соответствующей шириной в пикселях, а браузер использует эти значения для выбора между указанными изображениями. В показанном выше примере есть три версии одного и того же изображения в трёх разных размерах.
Атрибут sizes
задаёт пространство, которое изображение будет занимать на экране. В показанном выше примере изображение займёт до 1200px, если минимальная ширина экрана равна 1280px.
Тем не менее, рекомендуется не использовать тег Picture
только для смены разрешения, потому что ту же задачу можно решить с помощью новой версии тега Img
(имеющей поддержку большего количества браузеров).
<img srcset="small-car-image.jpg 400w,
medium-car-image.jpg 800w,
large-car-image.jpg 1200w"
sizes="(min-width: 1280px) 1200px,
(min-width: 768px) 400px,
100vw"
src="medium-car-image.jpg" alt="Car">
Однако в большинстве случаев нам нужно решать проблему и смены разрешения, и ориентации графики, и лучшим решением для этого является тег picture
.
Поэтому давайте посмотрим, как можно решить проблему ориентации графики с помощью тега picture
.
Ориентация графики при помощи атрибута media
Мы можем решить эту проблему, создав различные версии изображения для разных размеров экрана. Эти разные версии могут быть альбомными, портретными или любыми другими изменёнными версиями того же изображения.
С помощью тега picture
мы можем легко обеспечить смену разрешения, воспользовавшись несколькими тегами source
внутри тега picture
.
<picture>
<source ....>
<source ....>
<source ....>
</picture>
Затем можно использовать атрибут media
для задания различных условий среды, в которых будут использоваться эти источники. Также можно использовать атрибуты srcset
и sizes
аналогично тому, о чём мы говорили в предыдущем разделе.
В показанном ниже примере демонстрируется полная реализация ориентации графики и смены разрешения при помощи тега picture
.
<picture>
<source media="(orientation: landscape)"
srcset="land-small-car-image.jpg 200w,
land-medium-car-image.jpg 600w,
land-large-car-image.jpg 1000w"
sizes="(min-width: 700px) 500px,
(min-width: 600px) 400px,
100vw">
<source media="(orientation: portrait)"
srcset="port-small-car-image.jpg 700w,
port-medium-car-image.jpg 1200w,
port-large-car-image.jpg 1600w"
sizes="(min-width: 768px) 700px,
(min-width: 1024px) 600px,
500px">
<img src="land-medium-car-image.jpg" alt="Car">
</picture>
Если экран находится в альбомной ориентации, то браузер будет отображать изображения из первого набора, а если в портретной, то из второго набора. Кроме того, можно использовать атрибут media
с параметрами max-width
и min-width
:
<picture>
<source media="(max-width: 767px)" ....>
<source media="(min-width: 768px)" ....>
</picture>
Последний тег img
используется для обратной совместимости с браузерами, не поддерживающими теги picture
.
Использование с частично поддерживаемыми типами изображений
Благодаря быстрому развитию технологий ежедневно появляется множество современных типов изображений. Некоторые из них, например webp
, svg
и avif
, обеспечивают большее удобство для пользователей.
С другой стороны, у некоторых браузеров существуют ограничения в обработке этих современных типов изображений, и если не использовать совместимые типы изображений, это может вызвать проблемы.
Но мы можем с лёгкостью решить эту проблему при помощи тега Picture
, поскольку он позволяет нам указать внутри несколько источников.
<picture>
<source srcset="test.avif" type="image/avif">
<source srcset="test.webp" type="image/webp">
<img src="test.png" alt="test image">
</picture>
В показанный выше пример включены три типа изображений в форматах avif
, webp
и png
. Сначала браузер попробует формат avif
, если не получится, то попробует webp
. Если браузер не поддерживает ни один из них, то использует изображение png
.
Ситуация с тегом picture
стала ещё интереснее, когда разработчики Chrome объявили о том, что «во вкладке Rendering инструментов DevTools появится две новые эмуляции для эмулирования частично поддерживаемых типов изображений».
Начиная с Chrome 88 и далее можно использовать Chrome DevTools для проверки совместимости браузера с типами изображений.
Использование Chrome DevTools для эмулирования совместимости изображений
Хоть мы и говорили о том, насколько лучше тег picture
по сравнению с тегом img
, я уверен, что img
не умер и умрёт ещё не скоро.
Если мы будем с умом использовать имеющиеся у него атрибуты srcset
и size
, то можем выжать из тега img
максимум. Например, можно решить проблему смены разрешения при помощи одного только тега img
.
С другой стороны, можно использовать тег picture
, чтобы решить проблемы и смены разрешения, и ориентации графики с помощью запросов условий среды и других атрибутов.
Среди прочих достоинств тега picture
способность работать с частично поддерживаемыми типами изображений и поддержка Chrome DevTools.
Однако оба эти элемента имеют свои плюсы и минусы. Поэтому нам нужно обдумывать и выбирать наиболее подходящий к нашим требованиям элемент.