Cette page a été traduite à partir de l'anglais par la communauté. Vous pouvez contribuer en rejoignant la communauté francophone sur MDN Web Docs.

View in English Always switch to English

<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 ⁨juillet 2015⁩.

* Some parts of this feature may have varying levels of support.

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

Exemple interactif

<img
  class="fit-picture"
  src="/shared-assets/images/examples/grapefruit-slice.jpg"
  alt="Tranche de pamplemousse sur une pile d'autres tranches" />
.fit-picture {
  width: 250px;
}

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

  • L'attribut src contient le chemin vers l'image à intégrer. Il n'est pas obligatoire si l'attribut srcset est disponible. Cependant, au moins un des attributs src ou srcset doit être fourni.
  • L'attribut alt contient un texte de remplacement pour l'image, qui est obligatoire et extrêmement utile pour l'accessibilité : les lecteurs d'écran lisent la valeur de cet attribut à leurs utilisateur·ice·s afin qu'ils·elles sachent ce que signifie l'image. Le texte alternatif est également affiché sur la page si l'image ne peut pas être chargée pour une raison quelconque : par exemple, erreurs réseau, blocage de contenu ou lien rompu.

Il existe de nombreux autres attributs pour répondre à divers besoins :

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

Cet élément inclut les attributs universels.

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.

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.

attributionsrc Expérimental

Indique au navigateur d'envoyer un en-tête Attribution-Reporting-Eligible avec la requête pour l'image.

Côté serveur, cela sert à déclencher l'envoi d'un en-tête Attribution-Reporting-Register-Source ou Attribution-Reporting-Register-Trigger dans la réponse afin d'enregistrer une source d'attribution ou un déclencheur d'attribution. L'en-tête de réponse renvoyé dépend de la valeur de l'en-tête Attribution-Reporting-Eligible ayant déclenché l'enregistrement.

La source ou le déclencheur correspondant est éteint lorsque le navigateur reçoit la réponse contenant le fichier image.

Note : Voir l'API sur les rapports d'attribution pour plus de détails.

Il existe deux versions de cet attribut :

  • Une forme booléenne (c'est-à-dire l'utilisation du nom attributionsrc seul) qui indique qu'on souhaite envoyer l'en-tête Attribution-Reporting-Eligible au même serveur que celui vers lequel pointe l'attribut src. Cela fonctionne quand la source d'attribution ou le déclencheur d'enregistrement sont gérés sur le même serveur. Lors de l'enregistrement d'un déclencheur d'attribution, cette propriété est optionnelle et une valeur booléenne sera utilisée si elle est absente.
  • Une valeur contenant une ou plusieurs URL, comme :
html
<img
  src="image-file.png"
  alt="Ma description d'image"
  attributionsrc="https://a.example/register-source
                     https://b.example/register-source" />

Cette forme s'avère utile lorsque la ressource demandée n'est pas située sur un serveur que vous contrôler, ou si vous souhaitez gérer l'enregistrement de la source d'attribution sur un serveur différent. Dans ce cas, on indique une ou plusieurs URL pour la valeur de attributionsrc. Lorsque la requête pour la ressource est émise, l'en-tête Attribution-Reporting-Eligible sera envoyé aux URL indiquées dans attributionSrc, ainsi qu'à l'origine de la ressource. Ces URL pourront ensuite répondre avec un en-tête Attribution-Reporting-Register-Source ou Attribution-Reporting-Register-Trigger afin de finaliser l'enregistrement.

Note : Indiquer plusieurs URL signifie que plusieurs sources d'attribution peuvent être enregistrées pour la même fonctionnalité. On peut par exemple avoir plusieurs campagnes dont on souhaite mesurer les performances, via différents rapports sur différentes données.

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 cookies, certificat X.509 (angl.), 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

Cet attribut fournit une indication au navigateur sur la façon de décoder l'image : soit en effectuant le décodage de l'image en même temps que le rendu du reste du contenu du DOM, dans une seule étape de présentation qui paraît plus « correcte » (sync), soit en rendant et présentant d'abord le reste du contenu du DOM puis en décodant l'image et en la présentant ensuite (async). En pratique, async signifie que le prochain affichage ne dépend pas de la fin du décodage de l'image.

Il est souvent difficile de percevoir un effet notable lors de l'utilisation de decoding sur des éléments <img> statiques. Ils seront probablement d'abord rendus comme des images vides pendant que les fichiers image sont récupérés (depuis le réseau ou le cache), puis traités indépendamment, de sorte que la « synchronisation » des mises à jour de contenu est moins apparente. Cependant, le blocage du rendu pendant le décodage, bien que souvent très court, peut être mesuré — même s'il est difficile à observer à l'œil nu. Voir Que fait réellement l'attribut de décodage d'image ? (angl.) pour une analyse plus détaillée (tunetheweb.com, 2023).

L'utilisation de différents types de decoding peut entraîner des différences plus perceptibles lors de l'insertion dynamique d'éléments <img> dans le DOM via JavaScript — voir HTMLImageElement.decoding pour plus de détails.

Valeurs autorisées :

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 valeur 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 pour la récupération de l'image. Les valeurs autorisées sont :

high

L'image est récupérée avec une priorité plus élevée que les autres images.

low

L'image est récupérée avec une priorité plus faible que les autres images.

auto

La valeur par défaut. Il n'y a pas de préférence pour la priorité.

Voir HTMLImageElement.fetchPriority pour plus d'informations.

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 (angl.). 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 (angl.).

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 valeurs séparées par des virgules, qui peuvent être des tailles de source ou le mot-clé auto.

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.

Les conditions de média décrivent les propriétés de la zone d'affichage (viewport en anglais), et non celles de l'image. Par exemple, (height <= 500px) 1000px propose d'utiliser une source d'image de 1000px de large si la hauteur de la zone d'affichage est inférieure ou égale à 500px. Comme un descripteur de taille de source définit la largeur à utiliser pour l'image lors de la mise en page, la condition de média est généralement (mais pas nécessairement) basée sur la largeur.

Les valeurs de taille de source spécifient la taille d'affichage prévue de l'image. Les agents utilisateurs utilisent la taille de source courante pour sélectionner l'une des sources fournies par l'attribut srcset, lorsque ces sources sont décrites à l'aide de descripteurs de largeur (w). La taille de source sélectionnée affecte la taille intrinsèque de l'image (la taille d'affichage de l'image si aucun style CSS n'est appliqué). Si l'attribut srcset est absent ou ne contient aucune valeur avec un descripteur de largeur, alors l'attribut sizes n'a aucun effet.

Une valeur de taille de source peut être n'importe quelle longueur non négative. Elle ne doit pas utiliser de fonctions CSS autres que les fonctions mathématiques. Les unités sont interprétées de la même manière que dans les requêtes média, ce qui signifie que toutes les unités de longueur relative sont relatives à la racine du document et non à l'élément <img>. Par exemple, une valeur en em est relative à la taille de police racine, et non à la taille de police de l'image. Les valeurs en pourcentage ne sont pas autorisées.

Le mot-clé auto peut remplacer toute la liste des tailles ou la première entrée de la liste. Il n'est valide que lorsqu'il est combiné avec loading="lazy", et il correspond à la taille concrète de l'image. Comme la taille intrinsèque de l'image n'est pas encore connue, il est recommandé de spécifier aussi les attributs width et height (ou leurs équivalents CSS) pour éviter que le navigateur n'assume une largeur d'image par défaut de 300px. Pour une meilleure compatibilité avec les navigateurs qui ne prennent pas en charge auto, vous pouvez inclure des tailles de repli après auto dans l'attribut sizes :

html
<img
  loading="lazy"
  width="200"
  height="200"
  sizes="auto, (max-width: 30em) 100vw, (max-width: 50em) 50vw, calc(33vw - 100px)"
  srcset="
    swing-200.jpg   200w,
    swing-400.jpg   400w,
    swing-800.jpg   800w,
    swing-1600.jpg 1600w
  "
  src="swing-400.jpg"
  alt="Balancement de kettlebell" />
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 l'agent utilisateur 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é CSS margindoit ê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'id d'un autre élément.

Note : Cet attribut est considéré comme obsolète dans la spécification HTML (angl.). Son avenir est incertain ; il est recommandé d'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, height, etc, 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èques. Pour certains types d'image, cependant, des dimensions intrinsèques ne sont pas nécessaires. Les images SVG, par exemple, n'ont pas de dimensions intrinsèques si leur élément racine <svg> ne possède pas d'attribut width ou height.

Accessibilité

Rédiger des descriptions alternatives pertinentes

La valeur d'un attribut alt doit fournir un texte de remplacement clair et concis pour le contenu de l'image. Elle ne doit pas décrire la présence de l'image elle-même ni le nom du fichier de l'image. Si l'attribut alt est volontairement omis parce que l'image n'a pas d'équivalent textuel, envisagez d'autres méthodes pour présenter ce que l'image cherche à communiquer.

À ne pas faire

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

À faire

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

Un test important pour l'accessibilité consiste à lire le contenu de l'attribut alt avec le texte qui précède pour vérifier si cela transmet le même sens que l'image. Par exemple, si l'image était précédée de la phrase « Lors de mes voyages, j'ai vu un petit animal mignon : », l'exemple À ne pas faire pourrait être lu par un lecteur d'écran comme « Lors de mes voyages, j'ai vu un petit animal mignon : image », ce qui n'a pas de sens. L'exemple À faire pourrait être lu comme « Lors de mes voyages, j'ai vu un petit animal mignon : Un manchot sur une plage. », ce qui a du sens.

Pour les images utilisées pour déclencher une action, par exemple des images incluses dans un élément HTML <a> ou <button>, pensez à décrire l'action déclenchée dans la valeur de l'attribut alt. Par exemple, vous pouvez écrire alt="page suivante" au lieu de alt="flèche droite". Vous pouvez aussi ajouter une description complémentaire dans un attribut title ; celle-ci pourra être lue par les lecteurs d'écran si l'utilisateur·ice en fait la demande.

Lorsque l'attribut alt n'est pas présent sur une image, certains lecteurs d'écran peuvent annoncer le nom du fichier de l'image à la place. Cela peut prêter à confusion si le nom du fichier ne représente pas le contenu de l'image.

Identifier le SVG comme une image

En raison d'un bug VoiceOver, VoiceOver n'annonce pas correctement les images SVG comme des images. Ajoutez role="img" à tous les éléments <img> dont la source est un fichier SVG afin de garantir que les technologies d'assistance annoncent correctement le SVG comme contenu image.

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

L'attribut title

L'attribut title n'est pas un substitut acceptable à l'attribut alt. De plus, évitez de dupliquer la valeur de l'attribut alt dans un attribut title déclaré sur la même image. Cela peut amener certains lecteurs d'écran à annoncer deux fois le même texte, ce qui crée une expérience confuse.

L'attribut title ne doit pas non plus être utilisé comme information de légende supplémentaire pour accompagner la description alt d'une image. Si une image a besoin d'une légende, utilisez les éléments <figure> et <figcaption>.

La valeur de l'attribut title est généralement présentée à l'utilisateur·ice sous forme d'infobulle, qui apparaît peu après l'arrêt du curseur sur l'image. Bien que cela puisse fournir des informations supplémentaires, il ne faut pas supposer que l'utilisateur·ice la verra : il·elle peut n'utiliser qu'un clavier ou un écran tactile. Si vous avez une information particulièrement importante ou précieuse pour l'utilisateur·ice, présentez-la en ligne en utilisant l'une des méthodes mentionnées ci-dessus plutôt que title.

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="/shared-assets/images/examples/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="/shared-assets/images/examples/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="/shared-assets/images/examples/favicon72.png"
  alt="Logo MDN"
  srcset="/shared-assets/images/examples/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" />

Note : Pour voir le redimensionnement en action, voir l'exemple sur une page séparée, afin de pouvoir réellement redimensionner la zone de contenu.

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.

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 élément vide.
Omission de balises La balise ouvrante doit être présente et il ne doit pas y avoir de balise fermante.
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
# the-img-element

Compatibilité des navigateurs

Voir aussi