Get to know MDN better
Cette page a été traduite à partir de l'anglais par la communauté. Vous pouvez contribuer en rejoignant la communauté francophone sur MDN Web Docs.
Cette fonctionnalité est bien établie et fonctionne sur de nombreux appareils et versions de navigateurs. Elle est disponible sur tous les navigateurs depuis juillet 2015.
* Certaines parties de cette fonctionnalité peuvent bénéficier de prise en charge variables.
L'élément HTML <a> (ou élément d'ancre), avec son attribut href, crée un hyperlien vers des pages web, des fichiers, des adresses e-mail, des emplacements dans la même page ou toute autre ressource accessible par une URL.
Le contenu de chaque <a> doit indiquer la destination du lien. Si l'attribut href est présent, appuyer sur la touche Entrée lorsque l'élément <a> est sélectionné l'active.
Cet élément inclut les attributs universels.
attributionsrcDéfinit que vous souhaitez que le navigateur envoie un en-tête Attribution-Reporting-Eligible. Côté serveur, cela sert à déclencher l'envoi d'un en-tête Attribution-Reporting-Register-Source dans la réponse, afin d'enregistrer une source d'attribution basée sur la navigation.
Le navigateur stocke les données de la source associée à la source d'attribution basée sur la navigation (telles que fournies dans l'en-tête de réponse Attribution-Reporting-Register-Source) lorsque l'utilisateur·ice clique sur le lien. Voir l'API Attribution Reporting pour plus de détails.
Il existe deux versions de cet attribut :
Booléen, c'est-à-dire, uniquement le nom attributionsrc. Cela indique que vous souhaitez que l'en-tête Attribution-Reporting-Eligible soit envoyé au même serveur que celui indiqué par l'attribut href. Cela convient lorsque vous gérez l'enregistrement de la source d'attribution sur le même serveur.
Valeur contenant une ou plusieurs URL, par exemple :
Ceci est utile dans les cas où la ressource demandée n'est pas sur un serveur que vous contrôlez, ou si vous souhaitez simplement gérer l'enregistrement de la source d'attribution sur un autre serveur. Dans ce cas, vous pouvez définir une ou plusieurs URL comme valeur de attributionsrc. Lorsque la requête de ressource a lieu, l'en-tête Attribution-Reporting-Eligible est envoyé à l'(aux) URL(s) définie(s) dans attributionsrc en plus de l'origine de la ressource. Ces URL peuvent alors répondre avec Attribution-Reporting-Register-Source pour compléter l'enregistrement.
Note : Définir plusieurs URL signifie que plusieurs sources d'attribution peuvent être enregistrées sur la même fonctionnalité. Par exemple, vous pouvez avoir différentes campagnes dont vous souhaitez mesurer le succès, ce qui implique de générer différents rapports sur différentes données.
Les éléments HTML <a> ne peuvent pas être utilisés comme déclencheurs d'attribution, uniquement comme sources.
downloadFait en sorte que le navigateur traite l'URL liée comme un téléchargement. Peut être utilisé avec ou sans valeur filename :
Sans valeur, le navigateur propose un nom de fichier/extension, généré à partir de diverses sources :
filename : définir une valeur la suggère comme nom de fichier. Les caractères / et \ sont convertis en caractères de soulignement (_). Les systèmes de fichiers peuvent interdire d'autres caractères dans les noms de fichiers, les navigateurs ajustent donc le nom suggéré si nécessaire.
Note :
L'URL vers laquelle pointe l'hyperlien. Les liens ne sont pas limités aux URL basées sur HTTP : ils peuvent utiliser n'importe quel schéma d'URL pris en charge par les navigateurs :
D'autres fonctionnalités des URL permettent de localiser des parties spécifiques de la ressource :
Donne des indications sur le langage humain de l'URL liée. Aucune fonctionnalité intégrée. Les valeurs autorisées sont les mêmes que l'attribut universel lang.
pingContient une liste d'URL séparées par des espaces vers lesquelles sont envoyées des requêtes POST avec le corps PING lorsque l'utilisateur·ice suit le lien. Cet attribut est généralement utilisé pour tracer un·e utilisateur·ice.
interestforDéfinit l'élément <a> comme un invocateur d'intérêt (interest invoker). Sa valeur est l'id de l'élément cible, qui est affecté d'une manière ou d'une autre (généralement affiché ou masqué) lorsque l'intérêt est montré ou perdu sur l'élément invocateur (par exemple au survol/fin de survol ou à la sélection/perte de sélection). Voir Utilisation des invocateurs d'intérêt pour plus de détails et d'exemples.
referrerpolicyDétermine la quantité d'informations du référent à envoyer lors du suivi du lien.
Cet attribut indique la relation entre la cible du lien et l'objet faisant le lien. La valeur est une liste de types de liens séparés par des espaces.
targetOù afficher l'URL liée, comme nom d'un contexte de navigation (un onglet, une fenêtre ou un <iframe>). Les mots-clés suivants ont des significations spéciales pour l'endroit où charger l'URL :
Note : Définir target="_blank" sur les éléments <a> fournit implicitement le même comportement rel que définir rel="noopener" qui ne définit pas window.opener. Voir la compatibilité des navigateurs pour le support.
Donne des indications sur le format de l'URL liée avec un type MIME. Aucune fonctionnalité intégrée.
Fait allusion aux encodages des caractères de l'URL liée.
Note : Cet attribut est déprécié et ne doit pas être utilisé par les auteur·ice·s. Utilisez l'en-tête HTTP Content-Type sur l'URL liée.
Utilisé avec l'attribut shape. Une liste de coordonnées séparées par des virgules.
nameÉtait nécessaire pour définir un emplacement cible possible dans une page. En HTML 4.01, id et name pouvaient tous deux être utilisés sur <a>, pour autant qu'ils aient des valeurs identiques.
Note : Utilisez l'attribut universel id à la place.
Définissait un lien inverse ; l'opposé de l'attribut rel. Déprécié pour avoir été très confus.
shapeLa forme de la région de l'hyperlien dans une carte d'image.
Note : Utilisez plutôt l'élément <area> pour les cartes d'images.
Le contenu d'un lien doit indiquer où va le lien, même hors contexte.
Une erreur tristement courante consiste à ne relier que les mots « cliquez ici » ou « ici » :
Heureusement, il s'agit d'une solution facile, et elle est en fait plus courte que la version inaccessible !
Les logiciels d'assistance disposent de raccourcis permettant de lister tous les liens d'une page. Cependant, un texte de lien fort profite à tous les utilisateur·ice·s — le raccourci « liste de tous les liens » imite la façon dont les utilisateur·ice·s voyants parcourent rapidement les pages.
Les ancres sont souvent détournées avec l'évènement onclick afin de créer des pseudo-boutons avec l'attribut href qui vaut "#" ou javascript:void(0) pour empêcher le rafraîchissement de la page.
Ces valeurs produisent des résultats inadéquats lorsqu'on copie/déplace des liens, qu'on ouvre des liens dans de nouveaux onglets ou fenêtres, qu'on ajoute des marque-pages ou lorsque le JavaScript est encore en train d'être téléchargé. De plus, la sémantique exposée par le document, utilisée par les outils d'assistance, est incorrecte.
Dans ces cas, on privilégie plutôt l'utilisation d'un bouton <button>. De façon générale, une ancre ne doit être utilisée que pour naviguer vers une URL correcte.
Les liens qui ouvrent un nouvel onglet ou une nouvelle fenêtre grâce à target="_blank", ainsi que les liens qui ouvrent des fichiers devraient fournir une indication sur ce qui se produit lorsqu'on clique sur ces liens.
Les personnes qui utilisent des outils d'assistance à la navigation comme des lecteurs d'écran et/ou qui souffrent de troubles de la vision, cognitifs peuvent être confuses lorsqu'un nouvel onglet, fichier ou une nouvelle fenêtre s'ouvre de façon inattendue. Les anciennes versions des lecteurs d'écran peuvent également ne pas annoncer ce comportement.
Un skip link (aussi appelé skipnav en anglais) est un élément a qui est placé le plus près possible de l'élément <body> et qui renvoie au début du contenu principal de la page.
Ce lien permet alors de passer plus facilement le contenu qui se répète sur l'ensemble des pages (l'en-tête et la barre de navigation par exemple).
Les skip links sont particulièrement utiles pour les personnes qui naviguent à l'aide d'outils d'assistance (commande vocale, stylets buccal ou frontal) pour lesquels devoir passer par des liens répétés peut freiner la lecture du document.
Les éléments interactifs tels que les liens doivent fournir une surface suffisamment grande pour qu'il soit facile de les activer. Cela facilite la tâche à une variété de personnes : celles qui ont des problèmes moteur, celles qui utilisent des dispositifs de pointage peu précis (doigt ou stylet). La taille interactive minimale recommandée est de 44x44 pixels CSS (angl.).
Les liens en texte seul dans le contenu en prose sont exemptés de cette exigence, mais il est toujours bon de s'assurer qu'il y a suffisamment de texte hyperlié pour être facilement activé.
Lorsque plusieurs contenus interactifs (y compris les ancres) sont placés les uns à côté des autres, il est nécessaire de les espacer suffisamment pour minimiser le risque d'activer le mauvais contenu lors de la navigation.
Un tel espacement peut être obtenu grâce à la propriété CSS margin.
Note : Vous pouvez utiliser href="#top" ou le fragment vide (href="#") pour créer un lien vers le haut de la page actuelle, comme défini dans la spécification HTML (angl.).
Pour créer des liens qui s'ouvrent dans le programme de messagerie de l'utilisateur·ice, pour lui permettre d'envoyer un nouveau message, utilisez le schéma mailto: :
Pour plus de détails sur les URL mailto:, comme l'inclusion d'un sujet ou d'un corps de message, voir Liens de courrier électronique ou RFC 6068.
tel: le comportement du lien varie en fonction des capacités du périphérique :
Voir RFC 3966 pour la syntaxe, les fonctionnalités supplémentaires et d'autres détails sur le schéma URL tel:.
Pour enregistrer le contenu d'un élément <canvas> sous forme d'image, vous pouvez créer un lien avec un attribut download et les données du canvas sous forme d'une URL data: :
Les éléments <a> peuvent avoir des conséquences sur la sécurité et la vie privée des utilisateur·ice·s. Voir Referer en-tête : problèmes de confidentialité et de sécurité pour plus d'informations.
L'utilisation de target="_blank" sans rel="noreferrer" ni rel="noopener" rend le site vulnérable aux attaques exploitant l'API window.opener. Notez toutefois que, dans les versions récentes des navigateurs, définir target="_blank" fournit implicitement la même protection que rel="noopener". Voir la compatibilité des navigateurs pour plus de détails.
| Contenu du flux, contenu phrasé, contenu interactif, contenu tangible. |
| Transparent, contenant soit le contenu du flux (à l'exclusion du contenu interactif), soit contenu phrasé. |
| Aucune, la balise d'ouverture et la balise de fermeture sont obligatoires. |
| Tout élément qui accepte la formulation du contenu, ou tout élément qui accepte le contenu du flux, mais pas les autres éléments <a>. |
| link lorsque l'attribut href est présent, sinon generic |
|
Lorsque l'attribut href est présent : Lorsque l'attribut href n'est pas présent :
|
| HTMLAnchorElement |
| HTML # the-a-element |
Activez JavaScript pour afficher ce tableau de compatibilité des navigateurs.
Cette page a été modifiée le 13 mai 2026 par les contributeur·ice·s du MDN.
Votre modèle pour un internet meilleur.
Visitez la société mère à but non lucratif de Mozilla Corporation, la Fondation Mozilla.
Certaines parties de ce contenu sont protégées par le droit d'auteur ©1998—2026 des contributeurs individuels de mozilla.org. Contenu disponible sous une licence Creative Commons.