<img> : l'élément d'image embarquée

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.

L'élément HTML <img> permet d'intégrer une image dans un document.

Exemple interactif

L'exemple qui précède illustre l'utilisation de l'élément <img> :

  • L'attribut src est obligatoire, et contient le chemin vers l'image qu'on veut intégrer.
  • L'attribut alt contient une description textuelle de l'image, ce qui n'est pas obligatoire mais extrêmement utile pour l'accessibilité. En effet, les outils de lecture d'écran utilisent cette description pour la lire afin que les personnes sachent ce que l'image représente. Ce texte alternatif sera également affiché sur la page si l'image ne peut pas être chargée (par exemple s'il y a des erreurs réseau, du blocage de contenu ou un lien périmé).

Il existe de nombreux autres attributs :

  • Le contrôle du référent et de la politique de gestion des ressources d'origines multiples (CORS) avec les attributs crossorigin et referrerpolicy.
  • width et height qui permettent de définir la taille intrinsèque de l'image, lui permettant ainsi de prendre l'espace nécessaire avant son chargement (évitant ainsi d'avoir des décalages indésirables lors du chargement de la page).
  • Des indications responsives avec sizes et srcset (voir également l'élément <picture> et le tutoriel sur les images adaptatives).

Formats d'image pris en charge

Le standard HTML n'indique pas les formats d'image qui doivent être pris en charge, les agents utilisateurs peuvent prendre en charge différents formats.

Note : Le guide sur les types de fichier et formats d'image contient de nombreuses informations sur les formats d'image et leur prise en charge dans les navigateurs. La section qui suit n'est qu'un résumé !

Les formats d'image qu'on rencontre le plus fréquemment sur le Web sont :

Les formats comme WebP et AVIF sont recommandés, car avec de meilleures performances que PNG, JPEG, GIF tant pour les images animées que statiques. WebP dispose d'une large prise en charge tandis qu'AVIF n'est pas pris en charge par Safari.

SVG reste le format recommandé pour les images qui doivent être dessinées avec précision quelle que soit la taille.

Erreur de chargement d'une image

Si une erreur se produit lors du chargement ou du rendu de l'image et qu'un gestionnaire d'évènement onerror a été défini pour intercepter l'évènement error, le gestionnaire sera appelé. Cela peut arriver pour plusieurs raisons :

  • L'attribut src est vide ("") ou absent (null pour le DOM).
  • L'URL utilisée pour l'attribut src est la même que celle de la page courante.
  • L'image est corrompue et ne peut être chargée ainsi.
  • Les métadonnées associées à l'image sont corrompues de telle façon qu'il est impossible de connaître ses dimensions et qu'aucune dimension n'a été fournie pour les attributs de l'élément <img>.
  • Le format de l'image n'est pas pris en charge par l'agent utilisateur (généralement le navigateur).

Attributs

On peut utiliser les attributs universels sur cet élément.

alt

Définit une description textuelle alternative pour l'image.

Note : Il se peut que les navigateurs n'affichent pas l'image, cela peut se produire si :

  • Le navigateur n'est pas doté d'une interface visuelle
  • La personne a configuré son navigateur pour ne pas afficher les images (afin d'économiser de la bande passante ou pour des raisons de vie privée)
  • L'image est invalide ou son format n'est pas pris en charge

Dans ces situations, le navigateur peut remplacer l'image avec le texte fourni par cet attribut. Aussi, il est grandement préférable de fournir une valeur utile pour alt dès que possible.

L'absence totale d'attribut alt indique que l'image n'est pas importante pour le contenu et qu'aucun équivalent textuel n'est disponible. Utiliser la chaîne de caractères vide comme valeur pour cet attribut (alt="") indique que cette image n'est pas importante pour le contenu (par exemple une décoration ou un pixel de pistage), dans ce cas, les navigateurs non-visuels peuvent ne pas la traiter pour le rendu. Les navigateurs visuels masqueront l'icône de l'image cassée si alt est vide et que le chargement de l'image a échoué.

Cet attribut est également utilisé pour copier/coller l'image vers du texte ou pour enregistrer un marque-page avec l'image associée.

crossorigin

Indique que la récupération de l'image doit être effectuée avec une requête CORS. Les données provenant d'une image chargée via une requête CORS peuvent être réutilisées dans un élément <canvas> sans que celui-ci soit considéré comme corrompu (tainted).

Si l'attribut crossorigin n'est pas indiqué, une requête sans CORS sera effectuée (c'est-à-dire sans l'en-tête de requête Origin) et le navigateur marquera la page comme potentiellement corrompue, empêchant d'accéder aux données de l'image et empêchant son utilisation dans les éléments <canvas>.

Si l'attribut crossorigin est présent, une requête CORS est envoyée (avec l'en-tête de requête Origin) ; si le serveur ne gère pas l'accès depuis les origines tierces (c'est-à-dire qu'il n'envoie aucun en-tête de réponse Access-Control-Allow-Origin ou qu'il n'inclut pas l'origine du site dans l'en-tête Access-Control-Allow-Origin), le navigateur bloquera le chargement de l'image et affichera une erreur CORS dans la console de développement.

Les valeurs autorisées pour cet attribut sont :

anonymous

Une requête CORS est envoyée sans informations d'authentification (c'est-à-dire sans cookie, certificat X.509, ou en-tête de requête Authorization).

use-credentials

La requête CORS est envoyée avec les informations d'authentification (cookies, certificat X.509 et/ou en-tête Authorization). Si le serveur ne permet pas le partage des informations d'authentification avec le site d'origine (avec Access-Control-Allow-Credentials: true comme en-tête de réponse), le navigateur marque l'image comme potentiellement corrompue et restreint l'accès à ses données.

Si la valeur de l'attribut est invalide, les navigateurs considèrent que la valeur anonymous a été utilisée. Voir les attributs de paramétrage du CORS pour plus d'informations.

decoding

Fournit au navigateur une indication pour décoder l'image. Les valeurs autorisées sont :

sync

L'image est décodée de façon synchrone afin d'être présentée de façon atomique avec le reste du contenu.

async

L'image est décodée de façon asynchrone afin de réduire le temps nécessaire à l'affichage du reste du contenu.

auto

La valeur par défaut qui indique qu'il n'y a pas de préférence. C'est le navigateur qui décide alors ce qui est le mieux.

elementtiming

Indique que l'image doit être observée par l'API PerformanceElementTiming. La vleur fournie devient un identifiant pour l'élément observé. Voir aussi la page de l'atttribut elementtiming.

fetchpriority

Fournit une indication de la priorité relative à utiliser poua la récupération de l'image. Les valeurs autorisées sont :

high

Indique une priorité plus élevée que les autres images pour la récupération de la ressource.

low

Indique une priorité plus faible que les autres images pour la récupération de la ressource.

auto

La valeur par défaut. Le navigateur utilise une heuristique pour déterminer automatiquement la priorité.

height

La hauteur intrinsèque de l'image, exprimée en pixels. Cette valeur doit être un nombre entier, sans unité.

Note : Inclure height et width permet au navigateur de calculer les proportions de l'image avant son chargement. Ces proportions sont utilisées pour réserver l'espace nécessaire afin d'afficher l'image et de réduire voire d'empêcher tout décalage à l'affichage, permettant ainsi une navigation plus agréable et de meilleures performances.

ismap

Cet attribut booléen indique que l'image fait partie d'une carte côté serveur. Dans ce cas, les coordonnées du clic sur l'image sont envoyés au serveur.

Note : Cet attribut est uniquement autorisé lorsque l'élément <img> est un descendant d'un élément <a> disposant d'un attribut href valide. Cela fournit une alternative lorsque la navigation se fait sans dispositif de pointage.

loading

Indique comment le navigateur devrait charger l'image :

  • eager
    • : L'image est chargée immédiatement, que l'image soit située dans la zone d'affichage (viewport) visible ou non. Il s'agit de la valeur par défaut.
  • lazy
    • : Le chargement de l'image est retardé jusqu'à ce que celle-ci soit située à une certaine distance, définie par le navigateur, de la zone d'affichage. L'idée est d'éviter de consommer de la bande passante et des ressources réseaux avant d'être relativement certain que l'image est nécessaire. Pour la plupart des cas d'usage, cela permet d'améliorer les performances.

    Note : Le retardement du chargement est uniquement activé lorsque JavaScript est activé dans le navigateur. Il s'agit d'une mesure pour limiter le pistage. En effet, si les scripts sont désactivés pour le navigateur et que le chargement retardé est actif, le pistage d'un utilisateur en fonction de sa position sur la page serait toujours possible (via des images placées à intervalle régulier sur la page). [!NOTE] Les images avec loading qui vaut lazy ne seront jamais chargées si elles n'ont pas d'intersection avec une partie visible d'un élément. Fournir les attributs width et height pour les images chargées à la demande règle ce problème et est recommandé par la spécification.

referrerpolicy

Une chaîne de caractères qui indique le référent à utiliser lors de la récupération de la ressource :

no-referrer

L'en-tête Referer n'est pas envoyé.

no-referrer-when-downgrade

L'en-tête Referer ne sera pas envoyé aux origines sans TLS/HTTPS.

origin:

Le référent envoyé sera limité à l'origine de la page référente, c'est-à-dire qu'il ne contiendra que le schéma, l'hôte et le port.

origin-when-cross-origin

Le référent envoyé aux autres origines sera limité au schéma, à l'hôte et au port. La navigation vers la même origine contiendra le chemin.

same-origin

Un référent sera envoyé vers les mêmes origines mais les requêtes vers d'autres origines ne contiendront pas de référent.

strict-origin

N'envoie l'origine du document comme référent que lorsque le niveau de sécurité du protocole reste le même (HTTPS→HTTPS) et pas lorsque la destination est moins sécurisée (HTTPS→HTTP).

strict-origin-when-cross-origin (la valeur par défaut)

Envoie l'URL complète lors d'une requête vers la même origine, n'envoie que l'origine pour les requêtes vers d'autres origines si le niveau de sécurité du protocole reste le même (HTTPS→HTTPS), n'envoie aucun en-tête correspondant vers une destination moins sécurisée (HTTPS→HTTP).

unsafe-url

Le référent inclut l'origine et le chemin (mais pas le fragment, le mot de passe ou le nom d'utilisateur). Cette valeur n'est pas sécurisée, car elle diffuse l'origine et les chemins de ressources protégées par TLS vers des origines non-sécurisées.

sizes

Une ou plusieurs chaînes de caractères séparées par des virgules et qui indiquent un ensemble de tailles de source possible. Chaque taille de source consiste en :

  1. Une condition de média. Celle-ci doit être absente pour le dernier élément de la liste.
  2. Une valeur de taille de source.

La condition de média décrit les propriétés de la zone d'affichage et pas de l'image. Ainsi, (max-height: 500px) 1000px proposera d'utiliser une source de largeur 1000px, si la zone d'affichage n'est pas plus haute que 500px.

Les valeurs pour les tailles de source indiquent la taille d'affichage souhaitée de l'image. Le navigateur utilise la taille de source courante correspondante pour sélectionner une des sources fournies par l'attribut srcset lorsque les sources y sont décrites avec un descripteur de largeur (w). La taille de source sélectionnée affecte la taille intrinsèque de l'image (c'est-à-dire la taille occupée à l'écran si aucun style CSS n'est appliqué). Si l'attribut srcset est absent ou qu'il ne contient pas de valeur avec un descripteur de largeur, l'attribut sizes aura aucun effet.

src

L'URL de l'image. Cet attribut est obligatoire. Pour les navigateurs qui prennent en charge srcset, l'image fourni par src est considérée comme une candidate avec un descripteur de densité de pixel à 1x, sauf si une image avec un tel descripteur est déjà définie dans srcset, ou si srcset contient des descripteurs w.

srcset

Une ou plusieurs chaînes de caractères séparées par des virgules, qui indiquent des sources possibles pour l'image que le navigateur pourra utiliser. Chaque chaîne de caractères se compose :

  1. D'une URL vers l'image
  2. Éventuellement, d'un espace suivi :
    • D'un descripteur de largeur (un entier positif suivi par w). Le descripteur de largeur est divisé par la taille de source fournie par l'attribut sizes afin de calculer la densité de pixel effective.
    • D'un descripteur de densité de pixel (un nombre décimal positif suivi par x).

Si aucun descripteur n'est indiqué, la source se voit affecter un descripteur par défaut de 1x.

Toute combinaison des deux types de descripteur sera invalide. De même, indiquer deux sources avec le même descripteur sera invalide.

L'agent utilisateur sélectionne une des sources disponibles comme il l'entend. Cette liberté permet de baser le choix sur d'autres facteurs comme les préférences de l'utilisateur ou les conditions réseau. Voir le tutoriel sur les images adaptatives pour un exemple.

width

La largeur intrinsèque de l'image, exprimée en pixels. La valeur doit être un nombre entier sans unité.

usemap

L'URL partielle (commençant par #) d'une carte d'image associée à l'élément.

Note : Cet attribut est invalide si l'élément <img> est à l'intérieur d'un élément <a> ou d'un élément <button>.

Attributs dépréciés

align Obsolète

Aligne l'image au sein de son contexte englobant. À la place de cet attribut, on privilégiera les propriétés CSS float et/ou vertical-align. Les valeurs autorisées pour cet attribut sont :

top

Équivalent à vertical-align: top ou vertical-align: text-top

middle

Équivalent à vertical-align: -moz-middle-with-baseline

bottom

La valeur par défaut, équivalent à vertical-align: unset ou vertical-align: initial

left

Équivalent à float: left

Équivalent à float: right

border Obsolète

La largeur de la bordure autour de l'image. La propriété CSS border doit être utilisée à la place.

hspace Obsolète

Le nombre de pixels d'espace blanc à droite et à gauche de l'image. La propriété margin doit être utilisée à la place.

longdesc Obsolète

Un lien vers une description plus détaillée de l'image. Les valeurs pouvaient être une URL ou l'identifiant d'un autre élément.

Note : Cet attribut est mentionné dans la spécification HTML 5.2 du W3C, mais a été retiré du standard évolutif HTML du WHATWG. Son avenir est incertain et mieux vaut utiliser une alternative WAI-ARIA comme aria-describedby ou aria-details.

name Obsolète

Un nom pour l'élément, l'attribut universel id doit être utilisé à la place.

vspace Obsolète

Le nombre de pixels d'espace blanc en haut et en bas de l'image. La propriété CSS margin doit être utilisée à la place.

Mettre en forme avec CSS

<img> est un élément remplacé. Sa propriété display par défaut vaut inline, mais ses dimensions par défaut sont définies par les valeurs intrinsèques de l'image, à la façon de inline-block. Il est tout à fait possible d'utiliser les propriétés border/border-radius, padding/margin, width, et height sur une image.

<img> n'a pas de ligne de base, donc lorsque les images sont utilisées dans un contexte de mise en forme en ligne avec vertical-align: baseline, le bas de l'image sera placé sur la ligne de base du texte.

La propriété object-position peut être utilisée afin de positionner l'image au sein de la boîte fournie par l'élément. La propriété object-fit peut être utilisée pour ajuster le dimensionnement de l'image au sein de la boîte (par exemple pour étirer ou rogner l'image dans la boîte si nécessaire).

Selon son type, une image peut avoir une largeur et une hauteur intrinsèque. Pour certains types d'image en revanche, de telles dimensions intrinsèques ne sont pas nécessaires. Ainsi, les images vectorielles (en SVG par exemple) n'ont pas de dimensions intrinsèques si leur racine (l'élément <svg>) n'a pas d'attribut width ou height défini.

Exemples

Fournir un texte alternatif

Dans l'exemple qui suit, l'image est accompagnée d'un texte alternatif qui sert l'accessibilité.

html
<img src="favicon144.png" alt="Logo de MDN" />

Créer un lien avec une image

Cet exemple intègre l'image précédente et la transforme en lien. Pour cela, l'élément <img> est placé au sein d'un élément <a>. Ici, le texte alternatif devrait décrire la ressource vers laquelle pointe le lien.

html
<a href="https://developer.mozilla.org">
  <img src="favicon144.png" alt="Visiter le site MDN" />
</a>

Utiliser l'attribut srcset

Dans cet exemple, on utilise l'attribut srcset avec une référence vers une version du logo en haute résolution. Pour les appareils avec une haute résolution, celle-ci sera chargée à la place à la place de l'image indiquée par src. Pour les agents utilisateurs qui prennent en charge l'attribut srcset, l'image référencée par l'attribut src sera considérée comme une candidate avec le descripteur 1x.

html
<img src="favicon72.png" alt="Logo MDN" srcset="favicon144.png 2x" />

Utiliser les attributs srcset et sizes

L'attribut src est ignoré par les agents utilisateurs qui le prennent en charge lorsque les descripteurs w sont présents. Lorsque la condition (max-width: 600px) est respectée, l'image large de 200 pixels sera chargée (car c'est celle qui est la plus proche de 200px). Dans les autres cas, c'est l'autre image qui est chargée.

html
<img
  src="clock-demo-200px.png"
  alt="Clock"
  srcset="clock-demo-200px.png 200w, clock-demo-400px.png 400w"
  sizes="(max-width: 600px) 200px, 50vw" />

Sécurité et vie privée

Bien que les éléments <img> puissent être utilisés innocemment, ils peuvent également avoir des effets indésirables en termes de sécurité et de vie privée. Voir cet article quant à l'en-tête Referer pour plus de détails.

Accessibilité

Écrire des descriptions alternatives significatives

La valeur d'un attribut alt devrait toujours décrire le contenu de l'image de façon claire et concise. Elle ne doit pas décrire la présence de l'image ou le nom du fichier de l'image. Si l'attribut alt est omis volontairement, car l'image n'a pas d'équivalent textuel, utilisez d'autres méthodes afin d'indiquer le message véhiculé par l'image.

Mauvaise pratique

html
<img alt="image" src="pingouin.jpg" />

Bonne pratique

html
<img alt="Un manchot Rockhopper sur une plage." src="pingouin.jpg" />

Lorsque l'attribut alt n'est pas présent sur une image, certains lecteurs d'écran pourront annoncer le nom du fichier de l'image. Cela peut être source de confusion si le nom du fichier n'est pas représentatif du contenu de l'image.

Identifier le contenu SVG comme image

En raison d'un bug VoiceOver, ce dernier n'annonce pas correctement les images SVG comme étant des images. Il faut inclure role="img" pour les éléments <img> basés sur des fichiers sources SVG afin de s'assurer que les outils d'assistance annoncent le contenu SVG comme une image.

html
<img src="mdn.svg" alt="MDN" role="img" />

L'attribut title

L'attribut title n'est pas un remplaçant acceptable pour l'attribut alt. Il vaut également mieux éviter de dupliquer la valeur de l'attribut alt dans un attribut title pour la même image. En effet, un tel doublon entraînera les lecteurs d'écran à annoncer deux fois la description, ce qui pourra être une source de confusion.

L'attribut title ne devrait pas être utilisé afin de compléter les informations de légende de l'image pour accompagner la description fournie par alt. Si une image a besoin d'une légende, on utilisera les éléments figure et figcaption.

La valeur de l'attribut title est généralement affichée via une bulle d'information qui apparaît au survol du curseur sur l'image. Bien que cet attribut puisse fournir des informations supplémentaires, on ne doit pas s'attendre à ce que toute personne le voit : par exemple lorsque la navigation est effectuée au clavier ou sur un écran tactile. Si les informations à afficher sont particulièrement importantes ou utiles, on utilisera les méthodes évoquées ci-avant plutôt que title.

Résumé technique

Catégories de contenu Contenu de flux, contenu phrasé, contenu intégré, contenu tangible. Si l'élément utilise l'attribut usemap, il fait également partie de la catégorie de contenu interactif.
Contenu autorisé Aucun, il s'agit d'un élément vide.
Omission de balises La balise ouvrante doit être présente et il ne doit pas y avoir de balise fermante.
Éléments parents autorisés Tout élément qui accepte du contenu intégré.
Rôle ARIA implicite
Rôles ARIA autorisés
Interface DOM HTMLImageElement

Spécifications

Specification
HTML Standard
# the-img-element

Compatibilité des navigateurs

BCD tables only load in the browser

Voir aussi