<picture> : l'élément d'image adaptative
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since March 2016.
L'élément HTML <picture>
est un conteneur utilisé afin de définir zéro ou plusieurs éléments <source>
destinés à un élément <img>
. Le navigateur choisira la source la plus pertinente selon la disposition de la page (les contraintes qui s'appliquent à la boîte dans laquelle l'image devra être affichée), selon l'appareil utilisé (la densité de pixels de l'affichage par exemple avec les appareils hiDPI) et selon les formats pris en charge (ex. WebP pour les navigateurs Chromium ou PNG pour les autres). Si aucune correspondance n'est trouvée parmi les éléments <source>
, c'est le fichier défini par l'attribut src
de l'élément <img>
qui sera utilisé.
Exemple interactif
L'agent utilisateur examine chaque attribut présent dans <source>
(srcset
, media
, and type
) pour sélectionner l'URL de la meilleure ressource selon la disposition de la page, les caractéristiques de l'écran de l'appareil, etc.
L'élément <picture>
peut être utilisé pour :
- Fournir une direction artistique : rogner, modifier des images selon différentes conditions de média
- Fournir différents formats d'image lorsque certains formats ne sont pas pris en charge par les navigateurs
Lorsqu'on fournit des versions haute densité d'une image pour les appareils avec un DPI élevé, on utilisera plutôt srcset
sur l'élément <img>
à la place. Ainsi, les navigateurs pourront choisir une image à plus basse densité dans un contexte où les flux réseaux doivent être économisés. De plus, il ne sera pas nécessaire d'écrire des requêtes média explicites.
Attributs
Cet élément inclut uniquement les attributs universels.
Notes d'utilisation
Il est possible d'utiliser la propriété CSS object-position
afin d'ajuster le positionnement de l'image dans le cadre de l'élément. La propriété object-fit
permet quant à elle de contrôler la façon dont la taille de l'image est ajustée.
Note : Ces propriétés doivent être utilisées sur les éléments <img>
fils et pas sur l'élément <picture>
.
Exemples
Utiliser l'attribut media
L'attribut media
de l'élément <source>
permet de rédiger une requête média qui sera évaluée par l'agent utilisateur afin de sélectionner ou non la source. Si la requête média est évaluée à false
, l'élément <source>
est ignoré.
<picture>
<source srcset="mdn-logo-wide.png" media="(min-width: 600px)" />
<img src="mdn-logo-narrow.png" alt="MDN" />
</picture>
Utiliser l'attribut type
L'attribut type
d'un élément <source>
permet d'indiquer le type MIME du fichier fourni via l'attribut srcset
. Si l'agent utilisateur ne prend pas en charge ce type de fichier, l'élément <source>
est ignoré.
<picture>
<source srcset="mdn-logo.svg" type="image/svg+xml" />
<img src="mdn-logo.png" alt="MDN" />
</picture>
Résumé technique
Catégories de contenu | Contenu de flux, contenu phrasé, contenu intégré. |
---|---|
Contenu autorisé |
Zéro ou plusieurs éléments <source> suivi d'un
élément <img> avec éventuellement des éléments
scriptés entre.
|
Omission de balises | Aucune, la balise d'ouverture et la balise de fermeture sont obligatoires |
Parents autorisés | Tout élément qui peut contenir du contenu intégré. |
Rôles ARIA autorisés | Aucun |
Interface DOM | HTMLPictureElement |
Spécifications
Specification |
---|
HTML Standard # the-picture-element |
Compatibilité des navigateurs
BCD tables only load in the browser
Voir aussi
<img>
<source>
- Les propriétés CSS aidant au positionnement et au redimensionnement :
object-position
etobject-fit