--- title: Liste des attributs HTML slug: Web/HTML/Attributs tags: - Attribut - HTML - Reference - Web translation_of: Web/HTML/Attributes ---
{{HTMLSidebar}}

Chaque élément HTML peut avoir un ou plusieurs attributs. Ces attributs sont des valeurs supplémentaires qui permettent de configurer les éléments ou d'adapter leur comportement.

Liste des attributs

Nom de l'attribut Éléments auxquels il s'applique Description
accept {{HTMLElement("form")}}, {{HTMLElement("input")}} La liste des types acceptés par le serveur. Généralement, il s'agit de types de fichier.
accept-charset {{HTMLElement("form")}} La liste des jeux de caractères pris en charge.
accesskey Attribut universel Cet attribut permet de définir un raccourci clavier pour activer un élément ou lui passer le focus.
action {{HTMLElement("form")}} L'URI d'un programme qui traite les informations envoyées par le formulaire.
align {{HTMLElement("applet")}}, {{HTMLElement("caption")}}, {{HTMLElement("col")}}, {{HTMLElement("colgroup")}}, {{HTMLElement("hr")}}, {{HTMLElement("iframe")}}, {{HTMLElement("img")}}, {{HTMLElement("table")}}, {{HTMLElement("tbody")}}, {{HTMLElement("td")}}, {{HTMLElement("tfoot")}} , {{HTMLElement("th")}}, {{HTMLElement("thead")}}, {{HTMLElement("tr")}} Cet attribut définit l'alignement horizontal de l'élément.
allow {{HTMLElement("iframe")}} Cet attribut définit les règles des fonctionnalités pour cette iframe.
alt {{HTMLElement("applet")}}, {{HTMLElement("area")}}, {{HTMLElement("img")}}, {{HTMLElement("input")}} Un texte alternatif à afficher lorsque l'élément ne peut pas être affiché.
async {{HTMLElement("script")}} Cet attribut indique que le script devrait être exécuté de façon asynchrone.
autocapitalize Attribut universel Cet attribut contrôle la façon dont un champ texte est saisi en majuscules de façon automatique.
autocomplete

{{HTMLElement("form")}}, {{HTMLElement("input")}}, {{HTMLElement("select")}}, {{HTMLElement("textarea")}}

Cet attribut indique que ces contrôles ou que ce formulaire peuvent être remplis automatiquement par le navigateur.
autofocus {{HTMLElement("button")}}, {{HTMLElement("input")}}, {{HTMLElement("keygen")}}, {{HTMLElement("select")}}, {{HTMLElement("textarea")}} Cet attribut indique que l'élément doit recevoir le focus automatiquement une fois que la page est chargée.
autoplay {{HTMLElement("audio")}}, {{HTMLElement("video")}} Cet attribut indique que l'élément audio ou vidéo doit être lancé dès que possible.
background {{HTMLElement("body")}}, {{HTMLElement("table")}}, {{HTMLElement("td")}}, {{HTMLElement("th")}}

Définit l'URL vers un fichier qui est une image.

Note : Bien que les navigateurs et les clients emails prennent en charge cet attribut, cet attribut est obsolète. On utilisera plutôt la propriété {{cssxref("background-image")}}.

bgcolor {{HTMLElement("body")}}, {{HTMLElement("col")}}, {{HTMLElement("colgroup")}}, {{HTMLElement("marquee")}}, {{HTMLElement("table")}}, {{HTMLElement("tbody")}}, {{HTMLElement("tfoot")}}, {{HTMLElement("td")}}, {{HTMLElement("th")}}, {{HTMLElement("tr")}}

Cet attribut indique la couleur d'arrière-plan pour l'élément.

Note : Cet attribut est un attribut historique. Veuillez utiliser la propriété CSS standard {{cssxref("background-color")}}.

border {{HTMLElement("img")}}, {{HTMLElement("object")}}, {{HTMLElement("table")}}

Cet attribut indique la largeur de la bordure.

Note : Cet attribut est un attribut historique. Veuillez utiliser la propriété CSS standard {{cssxref("border")}}.

buffered {{HTMLElement("audio")}}, {{HTMLElement("video")}} Cet attribut contient la valeur de l'intervalle de temps d'ores et déjà mis en mémoire tampon pour le média de l'élément.
challenge {{HTMLElement("keygen")}} Une chaîne de challenge qui est envoyée avec la clef publique.
charset {{HTMLElement("meta")}}, {{HTMLElement("script")}} Cet attribut déclare l'encodage de caractères utilisé pour la page ou le script.
checked {{HTMLElement("command")}}, {{HTMLElement("input")}} Cet attribut indique si l'élément doit être vérifié au chargement de la page.
cite {{HTMLElement("blockquote")}}, {{HTMLElement("del")}}, {{HTMLElement("ins")}}, {{HTMLElement("q")}} Cet attribut est une URI qui pointe vers la source de la citation ou de la modification.
class Attribut universel Cet attribut permet de définir la ou les classes auxquelles appartient un élément afin de le manipuler en script ou de le mettre en forme avec CSS.
code {{HTMLElement("applet")}} Cet attribut définit l'URL du fichier de classe qui doit être utilisé pour le chargement et l'exécution de l'applet.
codebase {{HTMLElement("applet")}} Cet attribut fournit une URL absolue ou relative du dossier contenant les fichiers .class de l'applet.
color {{HTMLElement("basefont")}}, {{HTMLElement("font")}}, {{HTMLElement("hr")}}

Cet attribut définit la couleur du texte grâce à un nom de couleur ou grâce à un code hexadécimal dans le format #RRGGBB.

Note : Cet attribut est un attribut historique. Veuillez utiliser la propriété CSS standard {{cssxref("color")}}.

cols {{HTMLElement("textarea")}} Cet attribut définit le nombre de colonnes pour le texte contenu dans un textarea.
colspan {{HTMLElement("td")}}, {{HTMLElement("th")}} Cet attribut définit le nombre de colonnes sur lequel une cellule doit s'étendre.
content {{HTMLElement("meta")}} Une valeur associée avec http-equiv ou name selon le contexte.
contenteditable Attribut universel Cet attribut indique si le contenu de l'élément peut être édité.
contextmenu Attribut universel Cet attribut fait référence à l'identifiant d'un élément {{HTMLElement("menu")}} qui sera utilisé comme menu contextuel pour l'élément.
controls {{HTMLElement("audio")}}, {{HTMLElement("video")}} Cet attribut indique si le navigateur doit afficher les contrôles de lecture du média pour l'utilisateur.
coords {{HTMLElement("area")}} Un ensemble de valeurs qui définit les coordonnées de la zone d'intérêt.
crossorigin {{HTMLElement("audio")}}, {{HTMLElement("img")}}, {{HTMLElement("link")}}, {{HTMLElement("script")}}, {{HTMLElement("video")}} Cet attribut gère les requêtes de différentes origines.
csp {{experimental_inline}} {{HTMLElement("iframe")}} Cet attribut définit la politique de sécurité de contenu que le document intégré doit respecter.
data {{HTMLElement("object")}} Cet attribut définit l'URL de la ressource.
data-* Attribut universel Grâce aux attributs de donnée, on peut associer des attributs personnalisés afin de transporter des informations spécifiques.
datetime {{HTMLElement("del")}}, {{HTMLElement("ins")}}, {{HTMLElement("time")}} Cet attribut indique la date et l'heure associées à l'élément.
decoding {{HTMLElement("img")}} Cet attribut indique la méthode préférée pour décoder l'image.
default {{HTMLElement("track")}} Cet attribut indique que la piste devrait être activée sauf si les préférences de l'utilisateur indique un autre choix.
defer {{HTMLElement("script")}} Cet attribut indique que le script doit être exécuté une fois que la page a été analysée.
dir Attribut universel Cet attribut définit la direction du texte (gauche à droite ou droite à gauche).
dirname {{HTMLElement("input")}}, {{HTMLElement("textarea")}}
disabled {{HTMLElement("button")}}, {{HTMLElement("command")}}, {{HTMLElement("fieldset")}}, {{HTMLElement("input")}}, {{HTMLElement("keygen")}}, {{HTMLElement("optgroup")}}, {{HTMLElement("option")}}, {{HTMLElement("select")}}, {{HTMLElement("textarea")}} Cet attribut indique si l'utilisateur peut interagir avec l'élément.
download {{HTMLElement("a")}}, {{HTMLElement("area")}} Cet attribut indique si l'hyperlien est utilisé afin de télécharger une ressource.
draggable Attribut universel Cet attribut indique si l'élément peut être déplacé/glissé.
dropzone Attribut universel Cet attribut indique si l'élément peut recevoir du contenu suite à un glisser/déposer.
enctype {{HTMLElement("form")}} Cet attribut définit le type de contenu des données de formulaire envoyées lorsque la méthode utilisée est POST.
enterkeyhint {{experimental_inline}} {{HTMLElement("textarea")}}, contenteditable Cet attribut indique le libellé ou l'icône à afficher sur la touche entrée des clavier virtuels. Cet attribut peut être utilisé sur les contrôles de formulaires ou sur les éléments qui sont éditables (par exemple avec l'attribut contenteditable).
for {{HTMLElement("label")}}, {{HTMLElement("output")}} Cet attribut décrit l'élément auquel se rapporte l'élément courant.
form {{HTMLElement("button")}}, {{HTMLElement("fieldset")}}, {{HTMLElement("input")}}, {{HTMLElement("keygen")}}, {{HTMLElement("label")}}, {{HTMLElement("meter")}}, {{HTMLElement("object")}}, {{HTMLElement("output")}}, {{HTMLElement("progress")}}, {{HTMLElement("select")}}, {{HTMLElement("textarea")}} Cet attribut indique le formulaire auquel l'élément se rapporte.
formaction {{HTMLElement("input")}}, {{HTMLElement("button")}} Cet attribut est l'URI du programme qui traite les données pour ces champs du formulaire. Il prend le pas sur l'attribut action défini pour {{HTMLElement("form")}}.
formenctype {{HTMLElement("input")}}, {{HTMLElement("button")}} Si le bouton ou le champ sert à l'envoi (type="submit"), cet attribut indique l'encodage utilisé pour l'envoi des données. Si cet attribut est indiqué, il surcharge l'attribut enctype du formulaire auquel est rattaché le bouton/champ.
formmethod {{HTMLElement("input")}}, {{HTMLElement("button")}} Si le bouton ou le champ sert à l'envoi (type="submit"), cet attribut indique la méthode HTTP pour envoyer les données (GET, POST, etc.). Si cet attribut est indiqué, il surcharge l'attribut method du formulaire auquel est rattaché le bouton/champ.
formnovalidate {{HTMLElement("input")}}, {{HTMLElement("button")}} Si le bouton ou le champ sert à l'envoi (type="submit"), cet attribut booléen indique que le formulaire ne doit pas être validé à l'envoi. Si cet attribut est indiqué, il surcharge l'attribut novalidate du formulaire auquel est rattaché le bouton/champ.
formtarget {{HTMLElement("input")}}, {{HTMLElement("button")}} Si le bouton ou le champ sert à l'envoi (type="submit"), cet attribut indique le contexte de navigation (onglet, fenêtre ou iframe) dans lequel afficher la réponse après l'envoi du formulaire. Si cet attribut est indiqué, il surcharge l'attribut target du formulaire auquel est rattaché le bouton/champ.
headers {{HTMLElement("td")}}, {{HTMLElement("th")}} Les identifiants des éléments <th> qui s'appliquent à cet élément.
height {{HTMLElement("canvas")}}, {{HTMLElement("embed")}}, {{HTMLElement("iframe")}}, {{HTMLElement("img")}}, {{HTMLElement("input")}}, {{HTMLElement("object")}}, {{HTMLElement("video")}}

Pour ces éléments, cet attribut définit la hauteur occupée par l'élément. Pour les autres éléments, on utilisera {{cssxref("height")}} property.

Note : Pour certains éléments comme {{HTMLElement("div")}},cet attribut est un reliquat et ne devrait plus être utilisé. C'est la propriété CSS {{cssxref("height")}} qui est la méthode standard pour définir la hauteur d'un élément.

hidden Attribut universel Cet attribut empêche le rendu d'un élément sur une page tout en conservant les éléments fils actifs.
high {{HTMLElement("meter")}} Cet attribut indique la borne inférieure de l'intervalle haut.
href {{HTMLElement("a")}}, {{HTMLElement("area")}}, {{HTMLElement("base")}}, {{HTMLElement("link")}} L'URL de la ressource liée.
hreflang {{HTMLElement("a")}}, {{HTMLElement("area")}}, {{HTMLElement("link")}} Cet attribut indique la langue utilisé pour la ressource liée.
http-equiv {{HTMLElement("meta")}}
icon {{HTMLElement("command")}} Cet attribut indique une image qui représente la commande.
id Attribut universel Cet attribut permet d'identifier un élément d'un document de façon unique. Il est généralement utilisé pour manipuler l'élément avec des scripts ou pour le mettre en forme avec CSS.
importance {{experimental_inline}} {{HTMLElement("iframe")}}, {{HTMLElement("img")}}, {{HTMLElement("link")}}, {{HTMLElement("script")}} Cet attribut indique la priorité relative pour la récupération (fetch) des ressources.
integrity {{HTMLElement("link")}}, {{HTMLElement("script")}}

Une fonctionnalité relative à la sécurité qui permet aux navigateurs de vérifier les fichiers qu'ils récupèrent.

intrinsicsize {{experimental_inline}} {{HTMLElement("img")}} Cet attribut indique au navigateur qu'il faut ignorer la taille intrinsèque de l'image et qu'il faut utiliser la taille indiquée avec les attributs.
inputmode {{HTMLElement("textarea")}}, contenteditable Cet attribut fournit une indication sur le type de donnée qui pourrait être saisi par l'utilisateur lors de l'édition du formulaire ou de l'élément. Cet attribut peut être utilisé sur les contrôles de formulaires ou sur les éléments qui sont éditables (par exemple avec l'attribut contenteditable).
ismap {{HTMLElement("img")}} Cet attribut indique que l'image contribue à une mosaïque d'images interactive côté serveur.
itemprop Attribut universel
keytype {{HTMLElement("keygen")}} Cet attribut définit le type de clé qui est généré.
kind {{HTMLElement("track")}} Cet attribut définit le type de piste textuelle.
label {{HTMLElement("optgroup")}}, {{HTMLElement("option")}}, {{HTMLElement("track")}} Cet attribut définit un titre, lisible par un utilisateur, pour l'élément.
lang Attribut universel Cet attribut définit la langue utilisée dans l'élément.
language {{HTMLElement("script")}} Cet attribut définit le langage de script utilisé dans l'élément.
loading {{experimental_inline}} {{HTMLElement("img")}}, {{HTMLElement("iframe")}} Cet attribut indique que l'élément doit être chargé à la demande.
list {{HTMLElement("input")}} Cet attribut constitue une liste d'options prédéfinie qui est suggérée à l'utilisateur.
loop {{HTMLElement("audio")}}, {{HTMLElement("bgsound")}}, {{HTMLElement("marquee")}}, {{HTMLElement("video")}} Cet attribut indique si le média courant doit recommencer au début une fois que sa lecture est terminée.
low {{HTMLElement("meter")}} Cet attribut indique la borne supérieure de l'intervalle bas.
manifest {{HTMLElement("html")}}

Cet attribut définit l'URL du manifeste du document pour la gestion du cache.

Cet attribut est obsolète, on utilisera plutôt <link rel="manifest">.

max {{HTMLElement("input")}}, {{HTMLElement("meter")}}, {{HTMLElement("progress")}} Cet attribut indique la valeur maximale autorisée.
maxlength {{HTMLElement("input")}}, {{HTMLElement("textarea")}} Cet attribut définit le nombre maximal de caractères autorisé dans l'élément.
minlength {{HTMLElement("input")}}, {{HTMLElement("textarea")}} Cet attribut définit le nombre minimal de caractères qui doivent être saisis dans l'élément.
media {{HTMLElement("a")}}, {{HTMLElement("area")}}, {{HTMLElement("link")}}, {{HTMLElement("source")}}, {{HTMLElement("style")}} Cet attribut est indication à propos du type de média pour la ressource liée.
method {{HTMLElement("form")}} Cet attribut définit la méthode HTTP à utiliser pour l'envoi des données du formulaire (GET par défaut ou POST)
min {{HTMLElement("input")}}, {{HTMLElement("meter")}} Cet attribut indique la valeur minimale autorisée.
multiple {{HTMLElement("input")}}, {{HTMLElement("select")}} Cet attribut indique si plusieurs valeurs peuvent être saisies pour des entrées de type email ou file.
muted {{HTMLElement("audio")}},{{HTMLElement("video")}} Cet attribut indique si le son de la vidéo doit être coupé lorsque la page est chargée initialement.
name {{HTMLElement("button")}}, {{HTMLElement("form")}}, {{HTMLElement("fieldset")}}, {{HTMLElement("iframe")}}, {{HTMLElement("input")}}, {{HTMLElement("keygen")}}, {{HTMLElement("object")}}, {{HTMLElement("output")}}, {{HTMLElement("select")}}, {{HTMLElement("textarea")}}, {{HTMLElement("map")}}, {{HTMLElement("meta")}}, {{HTMLElement("param")}} Le nom de l'élément qui peut être utilisé par le serveur pour identifier le champ d'un formulaire.
novalidate {{HTMLElement("form")}} Cet attribut indique que les données du formulaire ne doivent pas être validées lors de l'envoi.
open {{HTMLElement("details")}} Cet attribut indique si les détails seront affichés lors du chargement de la page.
optimum {{HTMLElement("meter")}} Cet attribut indique la valeur numérique optimale.
pattern {{HTMLElement("input")}} Cet attribut définit une expression rationnelle contre laquelle valider la valeur de l'élément.
ping {{HTMLElement("a")}}, {{HTMLElement("area")}}
placeholder {{HTMLElement("input")}}, {{HTMLElement("textarea")}} Cet attribut fournit une indication à l'utilisateur sur ce qu'il peut saisir dans le champ.
poster {{HTMLElement("video")}} Cet attribut est une URL qui indique l'image à afficher tant que l'utilisateur n'a pas lancé la vidéo ou déplacé le curseur.
preload {{HTMLElement("audio")}}, {{HTMLElement("video")}} Cet attribut indique si toute ou partie, voire aucune partie de la ressource doit être téléchargée en avance.
radiogroup {{HTMLElement("command")}}
readonly {{HTMLElement("input")}}, {{HTMLElement("textarea")}} Cet attribut indique si l'élément peut être édité.
referrerpolicy {{HTMLElement("a")}}, {{HTMLElement("area")}}, {{HTMLElement("iframe")}}, {{HTMLElement("img")}}, {{HTMLElement("link")}}, {{HTMLElement("script")}} Définit le référent (referrer) envoyé lors de la récupération de la ressource.
rel {{HTMLElement("a")}}, {{HTMLElement("area")}}, {{HTMLElement("link")}} Cet attribut définit la relation entre l'objet cible et l'objet du lien.
required {{HTMLElement("input")}}, {{HTMLElement("select")}}, {{HTMLElement("textarea")}} Cet attribut indique si l'élément doit obligatoirement être renseigné dans le formulaire.
reversed {{HTMLElement("ol")}} Cet attribut indique si la liste doit être affichée dans un ordre décroissant plutôt que dans un ordre croissant.
rows {{HTMLElement("textarea")}} Cet attribut définit le nombre de lignes pour la zone de texte.
rowspan {{HTMLElement("td")}}, {{HTMLElement("th")}} Cet attribut définit le nombre de lignes sur lesquelles une cellule doit s'étendre.
sandbox {{HTMLElement("iframe")}} Empêche un élément chargé dans une iframe d'utiliser certaines fonctionnalités (envoyer des formulaires ou ouvrir de nouvelles fenêtres par exemples).
scope {{HTMLElement("th")}} Définit les cellules sur lesquelles porte la cellule d'en-tête.
scoped {{HTMLElement("style")}}
selected {{HTMLElement("option")}} Cet attribut définit la valeur qui sera sélectionnée au chargement de la page.
shape {{HTMLElement("a")}}, {{HTMLElement("area")}}
size {{HTMLElement("input")}}, {{HTMLElement("select")}} Cet attribut définit la largeur de l'élément en pixels, si l'attribut type de l'élément vaut text ou password, cela correspond au nombre de caractères du champ.
sizes {{HTMLElement("link")}}, {{HTMLElement("img")}}, {{HTMLElement("source")}}
slot Attribut universel Cet attribut affecte un créneau pour un élément dans le shadow DOM.
span {{HTMLElement("col")}}, {{HTMLElement("colgroup")}}
spellcheck Attribut universel Cet attribut indique si la vérification orthographique est activée pour l'élément courant.
src {{HTMLElement("audio")}}, {{HTMLElement("embed")}}, {{HTMLElement("iframe")}}, {{HTMLElement("img")}}, {{HTMLElement("input")}}, {{HTMLElement("script")}}, {{HTMLElement("source")}}, {{HTMLElement("track")}}, {{HTMLElement("video")}} Cet attribut indique l'URL du contenu embarqué.
srcdoc {{HTMLElement("iframe")}}
srclang {{HTMLElement("track")}}
srcset {{HTMLElement("img")}}
start {{HTMLElement("ol")}} Cet attribut définit le première nombre de la liste si celui-ci est différent de 1.
step {{HTMLElement("input")}}
style Attribut universel Cet attribut définit des styles CSS qui auront la priorité sur ceux définis précédemment. Il ne devrait être utilisé qu'à des fins de tests car il est conseillé d'utiliser un/des fichier(s) à part pour gérer la mise en forme.
summary {{HTMLElement("table")}}
tabindex Attribut universel Cet attribut permet de modifier l'ordre dans la navigation à la tabulation.
target {{HTMLElement("a")}}, {{HTMLElement("area")}}, {{HTMLElement("base")}}, {{HTMLElement("form")}}
title Attribut universel Cet attribut définit un texte expliquant le contenu de l'élément et qui est généralement affiché sous la forme d'une bulle d'information au survol de l'élément.
translate Attribut universel Cet attribut indique si le contenu textuel de l'élément doit être traduit ou non.
type {{HTMLElement("button")}}, {{HTMLElement("input")}}, {{HTMLElement("command")}}, {{HTMLElement("embed")}}, {{HTMLElement("object")}}, {{HTMLElement("script")}}, {{HTMLElement("source")}}, {{HTMLElement("style")}}, {{HTMLElement("menu")}} Cet attribut définit le type de l'élément.
usemap {{HTMLElement("img")}}, {{HTMLElement("input")}}, {{HTMLElement("object")}}
value {{HTMLElement("button")}}, {{HTMLElement("option")}}, {{HTMLElement("input")}}, {{HTMLElement("li")}}, {{HTMLElement("meter")}}, {{HTMLElement("progress")}}, {{HTMLElement("param")}} Cet attribut définit la valeur par défaut qui sera affichée dans l'élément au chargement de la page.
width {{HTMLElement("canvas")}}, {{HTMLElement("embed")}}, {{HTMLElement("iframe")}}, {{HTMLElement("img")}}, {{HTMLElement("input")}}, {{HTMLElement("object")}}, {{HTMLElement("video")}}

Pour ces éléments, cet attribut définit la largeur occupée sur l'écran.

Note : Pour tous les autres éléments, comme {{HTMLElement("div")}}, il faut utiliser la propriété CSS standard {{cssxref("width")}} afin de définir la largeur.

wrap {{HTMLElement("textarea")}} Cet attribut indique l'utilisation du retour automatique à la ligne pour le texte de l'élément.

Attribut de contenu ou attribut IDL ?

En HTML, la plupart des attributs ont deux aspects : l'attribut de contenu et l'attribut IDL (pour Interface Definition Language ou langage de définition des interfaces).

L'attribut de contenu est l'attribut qu'on définit via le contenu (le code HTML) et qu'on obtenir et/ou définir via les méthodes {{domxref("element.setAttribute()")}} et {{domxref("element.getAttribute()")}}. L'attribut de contenu sera toujours une chaîne de caractères, y compris lorsque la valeur attendue est un entier. Ainsi, pour indiquer une maxlength d'un élément {{HTMLElement("input")}} à 42, on utilisera setAttribute("maxlength", "42") sur cet élément.

L'attribut IDL est également connu sous la forme d'une propriété JavaScript. Ce sont les attributs qu'on peut obtenir ou modifier via JavaScript sous la forme élément.toto. L'attribut IDL utilisera toujours la valeur de l'attribut de contenu sous-jacent, éventuellement en la modifiant pour renvoyer une valeur ou pour la modifier. Autrement dit, les attributs IDL, reflètent les attributs de contenu.

La plupart du temps, les attributs IDL renverront leurs valeurs, telles qu'elles sont utilisées. Par exemple, le type (l'attribut type) par défaut des éléments {{HTMLElement("input")}} vaut "text", et si on définit input.type="tototruc", l'élément <input> se comportera comme un élément de type text (en termes d'apparence et de comportement) mais le contenu de l'attribut type sera "tototruc". Cependant, l'attribut de type IDL renverra la chaîne "text".

Les attributs IDL ne sont pas toujours des chaînes de caractères. input.maxlength est un nombre par exemple (un entier long signé pour être précis). Lorsqu'on manipule des attributs IDL on utilisera toujours le type défini pour l'interface. Ainsi, input.maxlength renverra toujours un nombre et si on souhaite le définir, il faudra le faire avec un nombre, si on passe une valeur d'un autre type, cette valeur sera convertie grâce aux mécanismes de conversion habituels de JavaScript.

Les attributs IDL peuvent avoir d'autres types : entiers longs non-signés, URL, booléens, etc. Cependant, il n'existe pas de règle claire qui définisse le comportement des attributs IDL en fonction de l'attribut de contenu. La plupart du temps, les règles de cette spécification seront suivies.

Attributs booléens

Certains attributs de contenu (ex. required, readonly, disabled) sont des attributs booléens. Si un attribut booléen est présent, sa valeur correspondra à vrai (true), s'il est absent, sa valeur correspondra à faux (false).

HTML5 définit certaines restrictions quant aux valeurs autorisées pour les attributs booléens. Si un attribut est présent, sa valeur doit être :

Voici quelques exemples valides pour utiliser un attribut booléen :

<div itemscope>Ce fragment est du HTML valide mais du XML invalide.</div>
<div itemscope=itemscope>Ce fragment est du HTML valide mais du XML invalide.</div>
<div itemscope="">Ce fragment est du HTML valide et du XML valide.</div>
<div itemscope="itemscope">Ce fragment est du HTML et du XML valide mais est plus verbeux.</div>

Pour être tout à fait explicite, les valeurs "true" et "false" ne sont pas autorisées pour les attributs booléens. Pour représenter une valeur fausse, il faudra ne pas écrire l'attribut du tout.

Cette règle peut entraîner quelques incompréhensions : si on écrit checked="false" l'attribut checked sera présent et donc considéré comme vrai (true).

Voir aussi