Html img alt width

Html img alt width

Все любят картинки! Тег для вставки изображений на страницу.

  1. Кратко
  2. Пример
  3. Как пишется
  4. Атрибуты
    1. src
    2. alt
    3. width и height
    4. srcset
    5. sizes
    6. loading
    7. decoding
    1. Алёна Батицкая советует
    1. В каких случаях нужно использовать атрибут srcset? Как браузер будет его обрабатывать?

    Обновлено 22 февраля 2023

    Кратко

    Скопировать ссылку «Кратко» Скопировано

    Тег добавляет изображение на страницу.

    Растровые, векторные — любые, поддержка форматов уже зависит от браузера.

    Пример

    Скопировать ссылку «Пример» Скопировано

      img src="logo.png" alt="Логотип: собака, бегущая за мячом, изображено схематично">      

    Как пишется

    Скопировать ссылку "Как пишется" Скопировано

    Тег одиночный, у него нет закрывающей пары, контент в него не положить.

    Ссылка на картинку и другие параметры задаются с помощью атрибутов.

    Атрибуты

    Скопировать ссылку "Атрибуты" Скопировано

    src

    Скопировать ссылку "src" Скопировано

    Обязательный атрибут. В качестве значения указывается адрес картинки. Абсолютная или относительная ссылка до файла в любом допустимом формате.

    alt

    Скопировать ссылку "alt" Скопировано

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

    Если забыть добавить атрибут, то скринридер попытается прочесть название файла: в лучшем случае это будет logo - large , но может быть и b764b84c , что не очень информативно. Если оставить значение атрибута пустым, то скринридер посчитает это изображение декоративным, а не контентным. Если вы добиваетесь именно этого — отлично, но тогда, возможно, стоит вставить его как фоновую картинку с помощью CSS.

    Когда картинка по какой-то причине не загружается, браузеры отображают вместо неё альтернативный текст. Его даже можно стилизовать, если задать текстовые стили тегу .

    width и height

    Скопировать ссылку "width и height" Скопировано

    При помощи атрибутов width и height размеры изображения задаются прямо в HTML. Вы можете спросить: зачем так, ведь стиль нужно задавать с помощью CSS? Это нужно, чтобы избежать прыжков контента при загрузке страницы. Частая ситуация, когда картинка очень тяжёлая, а скорость интернета пользователя невысокая.

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

    При этом сами единицы измерения px указывать не нужно, браузер поймёт.

    srcset

    Скопировать ссылку "srcset" Скопировано

    Самый простой способ предложить браузеру версию картинки с повышенным разрешением — указать её в атрибуте srcset :

      src="logo.png" srcset="logo@2x.png 2x" alt="Логотип: собака, бегущая за мячом, изображено схематично"> img src="logo.png" srcset="logo@2x.png 2x" alt="Логотип: собака, бегущая за мячом, изображено схематично">      

    Для этого не нужен целый элемент , достаточно атрибута.

    Также атрибут srcset можно использовать в сочетании с атрибутом sizes , чтобы подсказать браузеру, какие варианты картинок есть, и помочь ему выбрать подходящие ситуации.

    sizes

    Скопировать ссылку "sizes" Скопировано

    HTML даёт возможность загружать разные изображения в зависимости от разных условий. Частая ситуация: разные картинки под разные ширины экранов.

    • srcset — атрибут, принимающий несколько строк, разделённых запятой. Каждая строка должна содержать ссылку на картинку и указание фактической ширины картинки, значения разделяются пробелом. При этом после ширины ставится единица измерения w, а не px.
    • sizes — атрибут, в котором указывается одно или несколько условий через запятую. Каждая строка состоит из медиавыражения и ширины блока для картинки, разделённых пробелом. Ширину блока для картинки можно указывать в любых единицах измерения, кроме процентов.
      src="logo-large.png" srcset block-code__original-line"> logo-small.png 320w, logo-medium.png 480w, logo-large.png 800w" sizes block-code__original-line"> (max-width: 320px) 280px, (max-width: 480px) 440px, 800px" alt="Логотип: собака, бегущая за мячом, изображено схематично"> img src="logo-large.png" srcset=" logo-small.png 320w, logo-medium.png 480w, logo-large.png 800w" sizes=" (max-width: 320px) 280px, (max-width: 480px) 440px, 800px" alt="Логотип: собака, бегущая за мячом, изображено схематично">      

    Как браузер читает эти атрибуты:

    1. Смотрит на ширину экрана устройства.
    2. Пытается определить подходящее условие из списка в атрибуте sizes .
    3. Смотрит на размер блока для изображения к этому медиавыражению.
    4. Загружает то изображение из списка в srcset , которое имеет тот же размер, что и выбранный слот. Если такого нет, то загрузится первое изображение, которое больше размера выбранного слота.

    При чтении кода из примера выше:

    • На экранах от 0 до 320 пикселей загрузится logo-small.png.
    • На экранах от 321 до 480 пикселей загрузится logo-medium.png.
    • На всех прочих ширинах (или если браузер не поддерживает эти атрибуты) загрузится logo-large.png.

    Браузер остановит проверку и чтение атрибутов, как только найдёт совпадение с условием. Поэтому располагайте условия от меньших к большим.

    loading

    Скопировать ссылку "loading" Скопировано

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

    Но бывает, что картинок на странице много, и нам нужно как-то подсказать браузеру: вот эти пока не загружай, дождись, пока пользователь до них прокрутит — и можно начать загрузку. В общем, сам разберись. Удобно, правда?

    Для этого можно указать поведение картинки в атрибуте loading :

    • eager , то есть немедленно (по умолчанию, как если вообще не указывать атрибут);
    • lazy , то есть лениво.

    Атрибут сравнительно свежий, и стоит свериться с таблицей поддержки, но это не так важно: атрибут loading работает как улучшение, и если браузер его не поддерживает, то ничего не сломается.

    decoding

    Скопировать ссылку "decoding" Скопировано

    Перед тем, как показать загруженную картинку, браузер декодирует её — превращает набор байтов в набор пикселей по подходящим алгоритмам. Для больших изображений декодирование может занимать сотни миллисекунд, во время которых страница блокируется.

    Если изображения не настолько важны, как текст вокруг них, можно попросить браузер декодировать картинки асинхронно. Тогда браузер приступит к их декодированию попозже, когда самое важное уже будет нарисовано. Или наоборот, можно попросить браузер: «Вот эта картинка очень важная, её нужно декодировать прямо сейчас».

    Подсказки задаются в атрибуте decoding :

    • async — декодировать асинхронно (можно попозже, когда получится);
    • sync — синхронно (нужно прямо сейчас);
    • auto — автоматически (браузер, решай сам).

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

    Подсказки

    Скопировать ссылку "Подсказки" Скопировано

    💡 Картинка может быть ссылкой: для этого оберните в .

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

    💡 Прописывайте ширину width и высоту height изображения, чтобы страница загружалась быстрее. Задавая значения этим атрибутам, не пишите px, только числа.

    💡 Используйте атрибуты sizes и srcset , чтобы ваша картинка адаптировалась к разным устройствам. Получается красиво, а страница загружается быстрее.

    Ещё примеры

    Скопировать ссылку "Ещё примеры" Скопировано

    Мы указали картинке её реальные размеры в атрибутах width и height , а потом задали ей резиновую ширину 50%, и чтобы высота была корректной, добавили height : auto — браузер сам подберёт подходящую высоту, он уже загрузил картинку и всё знает.

      src="https://doka.guide/html/img/dogs.png" width="1504" height="541" alt="Три собаки: одна смотрит влево, вторая закрыла глаза и спит, третья смотрит вправо"> img src="dogs.png" width="1504" height="541" alt="Три собаки: одна смотрит влево, вторая закрыла глаза и спит, третья смотрит вправо">      
     img  width: 50%; height: auto;> img  width: 50%; height: auto; >      

    На практике

    Скопировать ссылку "На практике" Скопировано

    Алёна Батицкая советует

    Скопировать ссылку "Алёна Батицкая советует" Скопировано

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

    Всё просто! Измени поведение картинки со строчного на блочное ( block ) или строчно-блочное ( inline - block ).

    🛠 Частый дизайнерский приём — наложение поверх картинки цветного оверлея. И если для фоновой картинки это можно сделать при помощи псевдоэлемента, то с тегом этот приём не сработает. Для этого элемента невозможно задать псевдоэлемент, так уж устроены замещаемые элементы, вроде , , и других.

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

      div class="parent"> img class="child" src="some-image.jpg" alt="Три собаки, все закрыли глаза и спят"> div>      
     .parent  position: relative; width: 50%;> .parent::after  content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgb(255 134 48 / 20%);> .child  display: block; width: 100%;> .parent  position: relative; width: 50%; > .parent::after  content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgb(255 134 48 / 20%); > .child  display: block; width: 100%; >      

    На собеседовании

    Скопировать ссылку "На собеседовании" Скопировано

    В каких случаях нужно использовать атрибут srcset ? Как браузер будет его обрабатывать?

    Скопировать ссылку "В каких случаях нужно использовать атрибут srcset? Как браузер будет его обрабатывать?" Скопировано

    Это вопрос без ответа. Вы можете помочь! Почитайте о том, как контрибьютить в Доку.

    Источник

    HTML Tag

    Girl in a jacket

    The tag is used to embed an image in an HTML page.

    Images are not technically inserted into a web page; images are linked to web pages. The tag creates a holding space for the referenced image.

    The tag has two required attributes:

    • src - Specifies the path to the image
    • alt - Specifies an alternate text for the image, if the image for some reason cannot be displayed

    Note: Also, always specify the width and height of an image. If width and height are not specified, the page might flicker while the image loads.

    Tip: To link an image to another document, simply nest the tag inside an tag (see example below).

    Browser Support

    Attributes

    Attribute Value Description
    alt text Specifies an alternate text for an image
    crossorigin anonymous
    use-credentials
    Allow images from third-party sites that allow cross-origin access to be used with canvas
    height pixels Specifies the height of an image
    ismap ismap Specifies an image as a server-side image map
    loading eager
    lazy
    Specifies whether a browser should load an image immediately or to defer loading of images until some conditions are met
    longdesc URL Specifies a URL to a detailed description of an image
    referrerpolicy no-referrer
    no-referrer-when-downgrade
    origin
    origin-when-cross-origin
    unsafe-url
    Specifies which referrer information to use when fetching an image
    sizes sizes Specifies image sizes for different page layouts
    src URL Specifies the path to the image
    srcset URL-list Specifies a list of image files to use in different situations
    usemap #mapname Specifies an image as a client-side image map
    width pixels Specifies the width of an image

    Источник

    Читайте также:  Оператор стрелка в python
Оцените статью