From 4d3b1c2c79113786e001e3bec551205cd34f818a Mon Sep 17 00:00:00 2001 From: MDN Date: Fri, 21 May 2021 00:42:40 +0000 Subject: [CRON] sync translated content --- files/fr/orphaned/web/api/svgstylable/index.html | 98 ++++++++ .../@media/prefers-reduced-transparency/index.html | 85 +++++++ files/fr/orphaned/web/css/@media/scan/index.html | 86 +++++++ files/fr/orphaned/web/css/@page/bleed/index.html | 80 +++++++ files/fr/orphaned/web/css/@page/marks/index.html | 83 +++++++ .../orphaned/web/html/element/isindex/index.html | 71 ++++++ .../orphaned/web/html/element/listing/index.html | 49 ++++ .../orphaned/web/html/element/multicol/index.html | 38 ++++ .../fr/orphaned/web/html/element/nextid/index.html | 60 +++++ .../web/html/preloading_content/index.html | 248 +++++++++++++++++++++ 10 files changed, 898 insertions(+) create mode 100644 files/fr/orphaned/web/api/svgstylable/index.html create mode 100644 files/fr/orphaned/web/css/@media/prefers-reduced-transparency/index.html create mode 100644 files/fr/orphaned/web/css/@media/scan/index.html create mode 100644 files/fr/orphaned/web/css/@page/bleed/index.html create mode 100644 files/fr/orphaned/web/css/@page/marks/index.html create mode 100644 files/fr/orphaned/web/html/element/isindex/index.html create mode 100644 files/fr/orphaned/web/html/element/listing/index.html create mode 100644 files/fr/orphaned/web/html/element/multicol/index.html create mode 100644 files/fr/orphaned/web/html/element/nextid/index.html create mode 100644 files/fr/orphaned/web/html/preloading_content/index.html (limited to 'files/fr/orphaned/web') diff --git a/files/fr/orphaned/web/api/svgstylable/index.html b/files/fr/orphaned/web/api/svgstylable/index.html new file mode 100644 index 0000000000..f0f30a82ce --- /dev/null +++ b/files/fr/orphaned/web/api/svgstylable/index.html @@ -0,0 +1,98 @@ +--- +title: SVGStylable +slug: orphaned/Web/API/SVGStylable +tags: + - API + - Reference + - SVG + - SVG DOM +translation_of: Web/API/SVGStylable +original_slug: Web/API/SVGStylable +--- +
{{APIRef("SVG")}}
+ +

Interface SVG stylisable

+ +

L'interface SVGStylable est implémentée sur tout les objets SVG pouvant avoir des attributs {{ SVGAttr("style") }}, {{SVGAttr("class")}} ou d'autre attributs modifiants leur présentation, leur affichage.

+ +

Aperçu de l'interface

+ + + + + + + + + + + + + + + + + + + + +
Implémente aussi/
Métodes +
    +
  • {{ domxref("CSSValue") }} getPresentationAttribute(in {{ domxref("DOMString") }} name)
  • +
+
Propriétés +
    +
  • readonly {{ domxref("SVGAnimatedString") }} className
  • +
  • readonly {{ domxref("CSSStyleDeclaration") }} style
  • +
+
NormeSVG 1.1 (2e Édition)
+ +

Propriétés

+ + + + + + + + + + + + + + + + + + + + + +
NomTypeDescription
className{{ domxref("SVGAnimatedString") }}Correspond à l'attribut {{ SVGAttr("class") }} de l'élément donné.
style{{ domxref("CSSStyleDeclaration") }}Correspond à l'attribut {{ SVGAttr("style") }} de l'élément donné.
+ +

Métodes

+ + + + + + + + + + + + + + + + +
Nom & ArgumentsRetourneDescription
getPresentationAttribute(in {{ domxref("DOMString") }} name){{ domxref("CSSValue") }}Retourne la valeur par défaut (ex: static) d'un attribut de présentation donné comme un objet de type {{ domxref("CSSValue") }}.
+ The returned object is live; changes to the objects represent immediate changes to the objects to which the {{ domxref("CSSValue") }} is attached.
+ +

Compatibilité entre les navigateurs

+ + + +

{{Compat("api.SVGStylable")}}

diff --git a/files/fr/orphaned/web/css/@media/prefers-reduced-transparency/index.html b/files/fr/orphaned/web/css/@media/prefers-reduced-transparency/index.html new file mode 100644 index 0000000000..cba1deb11d --- /dev/null +++ b/files/fr/orphaned/web/css/@media/prefers-reduced-transparency/index.html @@ -0,0 +1,85 @@ +--- +title: prefers-reduced-transparency +slug: orphaned/Web/CSS/@media/prefers-reduced-transparency +tags: + - CSS + - Caractéristique média + - Reference +translation_of: Web/CSS/@media/prefers-reduced-transparency +original_slug: Web/CSS/@media/prefers-reduced-transparency +--- +

{{CSSRef}}{{SeeCompatTable}}{{draft}}

+ +

La caractéristique média prefers-reduced-transparency permet de détecter si un utilisateur préfère (via un paramètre du système d'exploitation ou du navigateur) minimiser l'utilisation des effets de transparence.

+ +

Syntaxe

+ +
+
no-preference
+
Cette valeur indique que l'utilisateur n'a exprimé aucune préférence quant à l'utilisation des effets de transparence. Ce mot-clé correspond à false lorsqu'il est utilisé dans un contexte booléen.
+
reduce
+
Cette valeur indique que l'utilisateur a configuré le système afin de minimiser la quantité d'effets de transparence.
+
+ +

Préférences utilisateur

+ +

À l'heure actuelle, aucun navigateur ou agent utilisateur n'implémente cette préférence malgré la présence de réglages correspondants dans les systèmes d'exploitation.

+ +

Exemples

+ +

Par défaut, cet exemple utilise un effet de transparence qui diminue la lisibilité du contenu.

+ +

HTML

+ +
<div class="transparency">Boîte transparente</div>
+
+ +

CSS

+ +
.transparency {
+  opacity: 0.5;
+}
+
+@media (prefers-reduced-transparency: reduce) {
+  .transparency {
+    opacity: 1;
+  }
+}
+
+ +

Résultat

+ +

{{EmbedLiveSample("Exemples")}}

+ +

Spécifications

+ + + + + + + + + + + + + + + + +
SpécificationÉtatCommentaires
{{SpecName('CSS5 Media Queries', '#descdef-media-prefers-reduced-transparency', 'prefers-reduced-transparency')}}{{Spec2('CSS5 Media Queries')}}Définition initiale.
+ +

Compatibilité des navigateurs

+ + + +

{{Compat("css.at-rules.media.prefers-reduced-transparency")}}

+ +

Voir aussi

+ + + +

{{QuickLinksWithSubpages("/fr/docs/Web/CSS/@media/")}}

diff --git a/files/fr/orphaned/web/css/@media/scan/index.html b/files/fr/orphaned/web/css/@media/scan/index.html new file mode 100644 index 0000000000..4d9d38cde6 --- /dev/null +++ b/files/fr/orphaned/web/css/@media/scan/index.html @@ -0,0 +1,86 @@ +--- +title: scan +slug: orphaned/Web/CSS/@media/scan +tags: + - CSS + - Caractéristique média + - Reference +translation_of: Web/CSS/@media/scan +original_slug: Web/CSS/@media/scan +--- +
{{CSSRef}}
+ +

scan est une caractéristique média CSS (cf. {{cssxref("@media")}}) qui peut être utilisée afin de déterminer le processus utilisé pour composer l'image sur l'appareil d'affichage.

+ +

Syntaxe

+ +

La caractéristique scan est définie avec un mot-clé parmi ceux qui suivent :

+ +
+
interlace
+
L'image est composée avec un entrelacement grâce à des lignes intercalées (en deux passes).
+
progressive
+
L'image est composée ligne par ligne avec un balayage progressif.
+
+ +

Exemples

+ +

HTML

+ +
<p>Si votre écran utilise une composition avec entrelacement, ce texte devrait
+   être écrit avec une police sans serif/empattement. S'il utilise une composition
+   avec un balayage progressif, vous devriez voir une police avec serif/empattement.
+</p>
+
+ +

CSS

+ +
p {
+  font-family: cursive;
+}
+
+@media (scan: interlace) {
+  p {
+    font-family: sans-serif;
+  }
+}
+
+@media (scan: progressive) {
+  p {
+    font-family: serif;
+  }
+}
+ +

Résultat

+ +

{{EmbedLiveSample("Exemples")}}

+ +

Spécifications

+ + + + + + + + + + + + + + + + + + + + + +
SpécificationÉtatCommentaires
{{SpecName('CSS4 Media Queries', '#scan', 'scan')}}{{Spec2('CSS4 Media Queries')}}Aucune modification.
{{SpecName('CSS3 Media Queries', '#scan', 'scan')}}{{Spec2('CSS3 Media Queries')}}Définition initiale.
+ +

Compatibilité des navigateurs

+ + + +

{{Compat("css.at-rules.media.scan")}}

diff --git a/files/fr/orphaned/web/css/@page/bleed/index.html b/files/fr/orphaned/web/css/@page/bleed/index.html new file mode 100644 index 0000000000..3465aa1178 --- /dev/null +++ b/files/fr/orphaned/web/css/@page/bleed/index.html @@ -0,0 +1,80 @@ +--- +title: bleed +slug: orphaned/Web/CSS/@page/bleed +tags: + - CSS + - Descripteur + - Experimental + - Reference +translation_of: Web/CSS/@page/bleed +original_slug: Web/CSS/@page/bleed +--- +
{{CSSRef}}{{SeeCompatTable}}
+ +

Le descripteur bleed, associé à la règle @ {{cssxref("@page")}}, définit l'espace duquel le contenu peut dépasser de la boîte de la page. Ce descripteur aura un effet uniquement si le descripteur {{cssxref("@page/marks","marks")}} est utilisé pour afficher les marques de coupure.

+ +

Syntaxe

+ +
/* Valeurs avec un mot-clé */
+bleed: auto;
+
+/* Valeurs de longueur */
+/* Type <length>       */
+bleed: 8pt;
+bleed: 1cm;
+
+ +

Valeurs

+ +
+
auto
+
Cette valeur correspond à 6pt si {{cssxref("marks")}} vaut crop. Dans les autres cas, cette valeur vaut zéro.
+
{{cssxref("<length>")}}
+
Cette valeur indique la distance, dans chaque direction, de laquelle le contenu peut dépasser de la boîte de la page. Les valeurs négatives sont autorisées mais les différentes implémentations fixent différentes limites.
+
+ +

Syntaxe formelle

+ +{{csssyntax}} + +

Exemples

+ +
@page {
+  bleed: 1cm;
+  marks: crop;
+}
+
+ +

Spécifications

+ + + + + + + + + + + + + + + + +
SpécificationÉtatCommentaires
{{SpecName("CSS3 Paged Media", "#bleed", "bleed")}}{{Spec2("CSS3 Paged Media")}}Définition initiale.
+ +

{{cssinfo}}

+ +

Compatibilité des navigateurs

+ + + +

{{Compat("css.at-rules.page.bleed")}}

+ +

Voir aussi

+ + diff --git a/files/fr/orphaned/web/css/@page/marks/index.html b/files/fr/orphaned/web/css/@page/marks/index.html new file mode 100644 index 0000000000..bb0558bd4e --- /dev/null +++ b/files/fr/orphaned/web/css/@page/marks/index.html @@ -0,0 +1,83 @@ +--- +title: marks +slug: orphaned/Web/CSS/@page/marks +tags: + - CSS + - Descripteur + - Experimental + - Reference +translation_of: Web/CSS/@page/marks +original_slug: Web/CSS/@page/marks +--- +
{{CSSRef}}{{SeeCompatTable}}
+ +

Le descripteur marks, associé à la règle @ {{cssxref("@page")}}, est utilisé pour afficher des marques de coupure (crop marks) ou des croix d'alignement (cross marks). Les marques de coupure sont utilisées pour massicoter les pages et les croix d'alignement sont utilisées afin d'aligner plusieurs feuilles entre elles.

+ +

Les marques de coupure et d'alignement sont imprimées en dehors de la boîte de la page. Pour qu'il y ait l'espace nécessaire au dessin de ces symboles, les pages finales doivent être légèrement plus grandes que la boîtes de la page.

+ +

Syntaxe

+ +
/* Valeurs avec un mot-clé */
+marks: none;
+marks: crop;
+marks: cross;
+marks: crop cross;
+
+ +

Valeurs

+ +
+
crop
+
Les marques de découpe seront affichées sur la page finale.
+
cross
+
Les marques d'alignement seront affichées sur la page finale.
+
none
+
Aucune marque ne sera affichée.
+
+ +

Syntaxe formelle

+ +{{csssyntax}} + +

Exemples

+ +
@page {
+  marks: crop cross;
+}
+
+ +

Spécifications

+ + + + + + + + + + + + + + + + +
SpécificationÉtatCommentaires
{{SpecName('CSS3 Paged Media', '#marks', 'marks')}}{{Spec2('CSS3 Paged Media')}}Définition initiale.
+ +

Cette propriété CSS avait initialement été proposée pour la spécification CSS de niveau 2 mais a été abandonnée lors de la première révision.

+ +

{{cssinfo}}

+ +

Compatibilité des navigateurs

+ + + +

{{Compat("css.at-rules.page.marks")}}

+ +

Voir aussi

+ + diff --git a/files/fr/orphaned/web/html/element/isindex/index.html b/files/fr/orphaned/web/html/element/isindex/index.html new file mode 100644 index 0000000000..90e3a1539f --- /dev/null +++ b/files/fr/orphaned/web/html/element/isindex/index.html @@ -0,0 +1,71 @@ +--- +title: +slug: orphaned/Web/HTML/Element/isindex +tags: + - Déprécié + - Element + - HTML + - Reference + - Web +translation_of: Web/HTML/Element/isindex +original_slug: Web/HTML/Element/isindex +--- +
{{Obsolete_header}}{{HTMLRef}}
+ +

L'élément HTML <isindex> est un élément obsolète qui permet de placer un champ sur une page afin d'effectuer des recherches dans le document. <isindex> devait permettre de saisir une ligne de texte pour une requête, à la suite de cette saisie, le serveur renvoyait une liste de pages qui correspondait à la requête. La prise en charge de cet élément dépendait du navigateur et du serveur.

+ +

<isindex> est un élément déprécié depuis HTML 4.01 car on peut obtenir le même comportement grâce à un formulaire HTML (cf. {{HTMLElement("form")}}). Tous les navigateurs ont désormais retiré <isindex> comme élément (ce dernier est classé comme une fonctionnalité non-conforme dans le standard WHATWG).

+ +

Attributs

+ +

Comme les autres éléments HTML, cet élément prend en charge les attributs universels.

+ +
+
{{htmlattrdef("prompt")}}
+
La valeur de cet attribut sera le texte affiché dans le champ de saisie avant que l'utilisateur y saisisse un texte.
+
{{htmlattrdef("action")}}
+
Cet atttribut peut être utilisé afin d'envoyer la requête vers une URL différente. Cet attribut n'est pas défini par le W3C.
+
+ +

Exemples

+ +

HTML

+ +
<isindex prompt="Rechercher…" />
+ +

Résultat

+ +

{{EmbedLiveSample("Exemples")}}

+ +

Historique

+ +

En juin 1992, Dan Connolly indiquant sa préférence pour un autre type d'ancre par rapport à isindex.

+ +

En novembre 1992, les index sont plus considérés comme des liens que comme des documents. Pour cette raison, différentes solutions sont proposées et l'ergonomie des formulaires est mentionnée en référence au navigateur Dynatext : « le navigateur affiche des boutons, les champs textuels, l'utilisateur remplit les champs puis clique sur OK et les résultats de la requête sont récupérés sous la forme d'un tableau de contenu ».

+ +

Lors d'une discussion en novembre 1992, Kevin Hoadley remet en cause le besoin d'un élément isindex et propose de l'abandonné. Il propose d'utiliser un élément {{HTMLElement("input")}} (une idée également poussée par Steve Putz). Tim Berners-Lee explique alors que le but de isindex est de pouvoir agréger les résultats d'une recherche. Kevin répond alors qu'il n'apprécie pas le côté booléen de isindex et qu'il serait préférable d'avoir un système où tout puisse être recherché, il propose d'étendre le cadre du WWW avec une configuration httpd spécifique et de définir une correspondance entre les URI et les requêtes de recherche.

+ +

En 2016, le retrait de isindex de la spécification est proposé.

+ +

Spécifications

+ + + +

Compatibilité des navigateurs

+ + + +

{{Compat("html.elements.isindex")}}

+ +

Voir aussi

+ + diff --git a/files/fr/orphaned/web/html/element/listing/index.html b/files/fr/orphaned/web/html/element/listing/index.html new file mode 100644 index 0000000000..ccccd2af09 --- /dev/null +++ b/files/fr/orphaned/web/html/element/listing/index.html @@ -0,0 +1,49 @@ +--- +title: +slug: orphaned/Web/HTML/Element/listing +tags: + - Element + - HTML + - Obsolete + - Reference + - Web +translation_of: Web/HTML/Element/listing +original_slug: Web/HTML/Element/listing +--- +
{{Obsolete_header}}{{HTMLRef}}
+ +

L'élément HTML <listing> affiche le texte compris entre les balises d'ouverture et de fermeture sans interpréter le HTML contenu, et en utilisant une police à chasse fixe. Le standard HTML 2 recommande de ne pas casser les lignes si elles ne sont pas plus grandes que 132 caractères.

+ +
Note : N'utilisez pas cet élément + +
    +
  • Il est déprécié depuis HTML 3.2 et n'a jamais été implémenté d'une manière cohérente par tous les navigateurs. De plus, il est obsolète dans HTML5 et peut être rendu par les agents-utilisateurs conformes comme l'élément {{HTMLElement("pre")}}, qui interprète l'HTML contenu !
  • +
  • Utilisez plutôt l'élément {{HTMLElement("pre")}} ou si sémantiquement approprié, l'élément {{HTMLElement("code")}} en échappant '<' et '>' pour qu'ils ne soient pas interprétés.
  • +
  • Une police à espacement fixe peut aussi être obtenue en utilisant un simple élément {{HTMLElement("div")}}, et en appliquant une règle CSS utilisant la valeur de police générique monospace dans la propriété {{cssxref("font-family")}}
  • +
+
+ +

Attributs

+ +

Cet élément a aucun attribut spécifique en dehors des attributs universels, communs à tous les éléments.

+ +

Interface DOM

+ +

Cet élément implémente l'interface {{domxref('HTMLElement')}}.

+ +
+

Note d'implémentation : jusqu'à Gecko 1.9.2 inclus, Firefox implémentait l'interface {{domxref('HTMLSpanElement')}} pour cet élément.

+
+ +

Compatibilité des navigateurs

+ + + +

{{Compat("html.elements.listing")}}

+ +

Voir aussi

+ +
    +
  • Utilisez plutôt les éléments {{HTMLElement("pre")}} et {{HTMLElement("code")}}.
  • +
  • Les éléments {{HTMLElement("plaintext")}} et {{HTMLElement("xmp")}} sont similaires à {{HTMLElement("listing")}} mais sont également obsolètes.
  • +
diff --git a/files/fr/orphaned/web/html/element/multicol/index.html b/files/fr/orphaned/web/html/element/multicol/index.html new file mode 100644 index 0000000000..49034047bc --- /dev/null +++ b/files/fr/orphaned/web/html/element/multicol/index.html @@ -0,0 +1,38 @@ +--- +title: +slug: orphaned/Web/HTML/Element/multicol +tags: + - Experimental + - HTML + - Non-standard + - Obsolete + - Reference + - Web +translation_of: Web/HTML/Element/multicol +original_slug: Web/HTML/Element/multicol +--- +
{{HTMLRef}}{{non-standard_header}}{{obsolete_header}}
+ +

L'élément HTML <multicol> était un élement expérimental conçu afin de réaliser des agencements sur plusieurs colonnes.
+ Il n'a jamais eu une traction significative et n'est pas implémenté dans la plupart des navigateurs.

+ +
+

N'utilisez pas cet élément ! Pour implémenter un agencement sur plusieurs colonnes, vous devez utilisez les élements HTML classiques comme {{HTMLElement("div")}} et les fonctionnalités CSS permettant d'organiser plusieurs colonnes.

+
+ +

Spécifications

+ +

Cet élément ne fait partie d'aucune spécification.

+ +

Compatibilité des navigateurs

+ + + +

{{Compat("html.elements.multicol")}}

+ +

Voir aussi

+ + diff --git a/files/fr/orphaned/web/html/element/nextid/index.html b/files/fr/orphaned/web/html/element/nextid/index.html new file mode 100644 index 0000000000..4f576ca0d1 --- /dev/null +++ b/files/fr/orphaned/web/html/element/nextid/index.html @@ -0,0 +1,60 @@ +--- +title: ' : l''élément NeXT ID (Obsolète)' +slug: orphaned/Web/HTML/Element/nextid +tags: + - Déprécié + - Element + - HTML + - Obsolete + - Reference + - Web +translation_of: Web/HTML/Element/nextid +original_slug: Web/HTML/Element/nextid +--- +
{{HTMLRef}}{{Deprecated_header}}
+ +

L'élément HTML <nextid> est un élément obsolète qui était utilisé par l'outil de conception web NeXT afin de générer automatiquement des attributs {{htmlattrxref("name","a")}}. Cet élément fut l'un des premiers à disparaître du DTD public des versions HTML et est également l'un des premiers éléments HTML les moins compris.

+ +
+
HTML "0.a" - valable jusqu'au 10 janvier 1991
+
Aucun exemple disponible.
+
HTML "0.c" - à partir du 23 janvier 1991 et jusqu'au 23 novembre 1992
+
Cette version d'HTML ajoute <NEXTID> en tant que formulaire, non conforme à SGML, simplement utilisé comme valeur numérique.
+
HTML "0.d" - à partir du 26 novembre 1992 jusqu'au 4 mai 1993
+
Pendant cette période, NeXT et les anciens DTD indiquent que <NEXTID> ne peut prendre qu'un nombre comme valeur pour son attribut N.
+
HTML "1.k" - Version 1 (première version officielle)
+
Dans le premier brouillon officiel de HTML, <NEXTID> permet d'utiliser un nom dans son attribut plutôt qu'un seul nombre.
+
HTML "1.m" - Version 1 (deuxième version)
+
Dans le brouillon HTML qui suit, <NEXTID> peut être retiré de l'affichage grâce à une commande SGML.
+
HTML Version 2, niveau 1
+
L'élément ne peut être inclus dans les éléments {{HTMLElement("form")}}, {{HTMLElement("input")}}, {{HTMLElement("textarea")}}, {{HTMLElement("select")}} et {{HTMLElement("option")}}.
+
HTML Version 2, niveau 1 strict
+
Ajoute des exclusions supplémentaires pour les éléments dépréciés.
+
HTML Version 2, niveau 2
+
La version par défaut, qui permet d'utiliser et d'inclure l'ensemble des éléments et attributs d'HTML 2.
+
HTML Version 2, niveau 2 strict
+
Cette version exclut les éléments dépréciés et interdit d'utiliser certaines constructions (comme l'inclusion d'un titre (<h1-h6>) dans un lien ({{HTMLElement("a")}} ou des champs de saisie {{HTMLElement("input")}} qui ne soient pas des éléments de bloc).
+
HTML Version 3.2
+
<NEXTID> disparaît du DTD.
+
+ +

Attributs

+ +

À l'instar de l'ensemble des éléments HTML, cet élément inclut les attribus universels.

+ +
+
{{htmlattrdef("n")}}
+
Une référence à une ancre.
+
+ +

Compatibilité des navigateurs

+ + + +

{{Compat("html.elements.nextid")}}

+ +

Voir aussi

+ +
    +
  • {{HTMLElement("isindex")}}
  • +
diff --git a/files/fr/orphaned/web/html/preloading_content/index.html b/files/fr/orphaned/web/html/preloading_content/index.html new file mode 100644 index 0000000000..f5a7840335 --- /dev/null +++ b/files/fr/orphaned/web/html/preloading_content/index.html @@ -0,0 +1,248 @@ +--- +title: Précharger du contenu avec rel="preload" +slug: orphaned/Web/HTML/Preloading_content +tags: + - Guide + - HTML + - JavaScript + - Link + - Media + - Performance + - Web Performance + - as + - preload + - rel +translation_of: Web/HTML/Preloading_content +original_slug: Web/HTML/Preloading_content +--- +

La valeur preload de l'attribut rel pour l'élément <link> permet d'écrire des requêtes déclaratives de récupération au sein de l'élément <head>. On peut ainsi indiquer les ressources dont la page aura besoin peu après son chargement. Cela permet de les précharger au début du chargement de la page, avant que le rendu intervienne. On s'assure donc que les ressources nécessaires soient disponibles plus tôt, évitant ainsi de bloquer le rendu initial de la page et améliorant les performances.

+ +

Cet article est un guide sur le fonctionnement de <link rel="preload">.

+ +

Les bases

+ +

On utilise généralement l'élément <link> de façon assez simple afin de charger une feuille de style CSS pour la page :

+ +
<link rel="stylesheet" href="styles/main.css">
+ +

Dans le cas qui va nous intéresser, on utilisera l'attribut rel avec la valeur preload. Cela va permettre d'utiliser l'élément <link> pour précharger à peu près n'importe quelle ressource dont on aurait besoin. Dans la version la plus simple, il suffit d'indiquer :

+ +
    +
  • le chemin de la ressource à précharger via l'attribut href
  • +
  • et le type de la ressource via l'attribut as.
  • +
+ +

Voici un exemple d'application simple (vous pouvez consulter le code source de cet exemple JS et CSS et visualiser la démo live) :

+ +
<head>
+  <meta charset="utf-8">
+  <title>Exemple de préchargement pour JS et CSS</title>
+
+  <link rel="preload" href="style.css" as="style">
+  <link rel="preload" href="main.js" as="script">
+
+  <link rel="stylesheet" href="style.css">
+</head>
+
+<body>
+  <h1>Balles rebondissantes</h1>
+  <canvas></canvas>
+
+  <script src="main.js"></script>
+</body>
+ +

Ici, nous préchargeons nos fichiers CSS et JavaScript afin qu'ils soient disponibles dès qu'ils seront nécessaires au rendu de la page par la suite. Cet exemple est trivial, car le navigateur découvre probablement les éléments <link rel="stylesheet"> et <script> dans le même morceau de HTML que les préchargements, mais les avantages sont d'autant plus évidents que les ressources sont découvertes tardivement et qu'elles sont importantes. Par exemple :

+ +
    +
  • Les ressources qui sont pointées à partir du CSS, comme les polices ou les images.
  • +
  • Les ressources que JavaScript peut demander, comme JSON, les scripts importés ou les web workers.
  • +
  • Images et fichiers vidéo plus volumineux.
  • +
+ +

preload présente également d'autres avantages. L'utilisation de as pour spécifier le type de contenu à précharger permet au navigateur de :

+ +
    +
  • Donner la priorité au chargement des ressources de façon plus précise.
  • +
  • Stocker dans le cache pour les demandes futures, en réutilisant la ressource si nécessaire.
  • +
  • Appliquer la bonne politique de sécurité du contenu à la ressource.
  • +
  • Définissez les bons en-têtes de requête Accept pour celle-ci.
  • +
+ +

Quels sont les types de contenu qu'on peut précharger ?

+ +

Il est possible de précharger de nombreux types de contenu, voici les valeurs principales qu'on peut utiliser avec l'attribut as :

+ +
    +
  • audio : un fichier audio.
  • +
  • document : un document HTML destiné à être intégré dans un élément <frame> ou dans un élément <iframe>.
  • +
  • embed : une ressource destinée à être intégrée dans un élément <embed>.
  • +
  • fetch : une ressource à laquelle on accèdera via une requête fetch ou via une requête XHR (par exemple un ArrayBuffer ou un fichier JSON).
  • +
  • font : un fichier de police de caractère.
  • +
  • image : un fichier contenant une image .
  • +
  • object : une ressource à intégrer dans un élément <object>.
  • +
  • script : un fichier JavaScript.
  • +
  • style : une feuille de style CSS.
  • +
  • track : un fichier WebVTT.
  • +
  • worker : un web worker ou un worker partagé JavaScript.
  • +
  • video : un fichier vidéo, généralement utilisé dans un élément <video>.
  • +
+ +
+

Note : Le préchargement de vidéo est inclus dans la spécification Preload, mais n'est pas actuellement mis en œuvre par les navigateurs.

+
+ +
+

Note : Pour avoir plus de détails quant à ces valeurs et aux fonctionnalités web associées, vous pouvez consulter la spécification Preload et notamment les extensions à l'élément <link>. On notera également que la liste complète des valeurs acceptables pour l'attribut as est définie dans la spécification Fetch (cf. les destinations de requête).

+
+ +

Ajouter un type MIME

+ +

Les éléments <link> permettent d'utiliser un attribut type qui contient le type MIME de la ressource vers laquelle pointe l'élément. Cet attribut est particulièrement utile pour le préchargement : le navigateur pourra analyser l'attribut type afin de déterminer s'il prend en charge ce type de ressource. Le téléchargement ne démarrera que si c'est le cas, sinon, l'élément sera ignoré.

+ +

Vous pouvez voir un exemple de ce fonctionnement avec une vidéo (voir le code source complet et la version live) :

+ +
<head>
+  <meta charset="utf-8">
+  <title>Exemple de préchargement d'une vidéo</title>
+
+  <link rel="preload" href="sintel-short.mp4" as="video" type="video/mp4">
+</head>
+<body>
+  <video controls>
+    <source src="sintel-short.mp4" type="video/mp4">
+    <source src="sintel-short.webm" type="video/webm">
+    <p>Votre navigateur ne prend pas en charge les vidéos HTML5.
+       Voici <a href="sintel-short.mp4">un lien pour télécharger la vidéo</a>.</p>
+  </video>
+</body>
+ +

Dans cet exemple, les navigateurs qui prennent en charge le format MP4 préchargeront le fichier en question et l'utiliseront. En revanche, les navigateurs qui ne supportent que WebM pourront bien utiliser le second fichier mais celui-ci ne sera préchargé. Cet exemple illustre comment ajouter le préchargement dans une stratégie d'amélioration progressive.

+ +

Récupérer des ressources de différentes origines

+ +

Lors du préchargement de ressources qui sont récupérées avec CORS activé (par exemple. fetch(), XMLHttpRequest ou fonts), une attention particulière doit être apportée au paramétrage de l'attribut crossorigin sur votre <link>. L'attribut doit être défini pour correspondre au mode CORS et aux informations d'identification de la ressource, même lorsque la récupération n'est pas d'origine croisée.

+ +

Les fichiers pour les polices de caractères constituent un cas intéressant. En effet, pour différentes raisons, elles doivent être récupérées via un mode CORS anonyme (cf. les spécifications pour la récupération des polices si vous êtes intéressé par les détails).

+ +

Utilisons ce cas de figure comme exemple. Vous pouvez consulter le code source complet de l'exemple sur GitHub (et voir le résultat live ici) :

+ +
<head>
+  <meta charset="utf-8">
+  <title>Web font example</title>
+
+  <link rel="preload" href="fonts/cicle_fina-webfont.woff2" as="font" type="font/woff2" crossorigin>
+  <link rel="preload" href="fonts/zantroke-webfont.woff2" as="font" type="font/woff2" crossorigin>
+
+  <link href="style.css" rel="stylesheet">
+</head>
+<body>
+  …
+</body>
+ +

Non seulement nous fournissons les indications relatives au type MIME dans les attributs type, mais nous fournissons également l'attribut crossorigin pour nous assurer que le mode CORS du préchargement correspond à l'éventuelle demande de ressource de police.

+ +

Gérer les différents médias

+ +

Une qualité des éléments <link> est qu'ils gèrent l'attribut media. Ce dernier peut être utilisé afin de conditionner le chargement de la ressource selon le type de média voire selon des requêtes de média (media queries). En bref, il est possible de faire du chargement de ressources qui soit responsive !

+ +

Prenons un exemple simple (le code source est disponible sur GitHub, avec une démonstration live) :

+ +
<head>
+  <meta charset="utf-8">
+  <title>Exemple de préchargement responsive</title>
+
+  <link rel="preload" href="bg-image-narrow.png" as="image" media="(max-width: 600px)">
+  <link rel="preload" href="bg-image-wide.png" as="image" media="(min-width: 601px)">
+
+  <link rel="stylesheet" href="main.css">
+</head>
+<body>
+  <header>
+    <h1>Mon site</h1>
+  </header>
+
+  <script>
+    var mediaQueryList = window.matchMedia("(max-width: 600px)");
+    var header = document.querySelector('header');
+
+    if(mediaQueryList.matches) {
+      header.style.backgroundImage = 'url(bg-image-narrow.png)';
+    } else {
+      header.style.backgroundImage = 'url(bg-image-wide.png)';
+    }
+  </script>
+</body>
+ +

Vous pouvez ici voir qu'on a ajouté les attributs media sur les éléments <link> afin de charger une image étroite si l'utilisateur utilise un écran étroit ou une image plus large si l'écran de l'appareil est plus large. Il est toutefois nécessaire d'afficher la bonne image en en-tête selon le résultat de la requête média et on utilise donc Window.matchMedia / MediaQueryList (lire Tester les requêtes média pour plus d'informations sur ce point).

+ +

Il est ainsi beaucoup plus probable que la police soit disponible pour le rendu de la page, ce qui réduit les FOUT (flash de texte non stylisé).

+ +

Ce concept n'est pas limité aux images voire aux fichiers du même type ! Laissez libre cours à votre imagination ! On peut imaginer charger un diagramme SVG relativement simple si l'utilisateur est sur un écran étroit (où la bande passante et le processeur sont souvent plus limités) ou précharger un code JavaScript complexe, utilisé pour afficher un modèle 3D complexe lorsque l'appareil de l'utilisateur possède plus de ressources.

+ +

Utiliser des scripts et des préchargements différés

+ +

Un autre avantage de ce mécanisme est qu'on peut choisir d'exécuter des préchargements par script si besoin. Dans le fragment de code suivant, on crée une instance de HTMLLinkElement qu'on attache au DOM :

+ +
var preloadLink = document.createElement("link");
+preloadLink.href = "myscript.js";
+preloadLink.rel = "preload";
+preloadLink.as = "script";
+document.head.appendChild(preloadLink);
+
+ +

Cela signifie que le navigateur préchargera le fichier JavaScript sans pour autant l'utiliser immédiatement.

+ +

Pour utiliser le script en question, quand on en a besoin, on pourrait écrire :

+ +
var preloadedScript = document.createElement("script");
+preloadedScript.src = "myscript.js";
+document.body.appendChild(preloadedScript);
+ +

Cela permet de précharger un script et de différer son exécution jusqu'au moment où on en a besoin.

+ +

Les autres mécanismes de préchargement

+ +

Il existe d'autres fonctionnalités qui permettent de précharger des ressources mais aucune n'est aussi flexible que <link rel="preload"> :

+ +
    +
  • <link rel="prefetch"> est pris en charge par les navigateurs depuis longtemps mais sert pour précharger des ressources qui seront utilisées sur la prochaine page vers laquelle on navigue. Autrement dit, c'est utile mais pas pour la page courante ! De plus, les navigateurs choisiront une priorité moins élevée pour les ressources prefetch que pour celles utilisant preload (la page actuelle est considérée comme plus importante que la suivante). Pour plus de détails, lire la FAQ sur le préchargement des liens.
  • +
  • <link rel="prerender"> est utilisé afin d'afficher la page indiquée en arrière-plan, accélérant le chargement de la page si l'utilisateur navigue vers cette page. Pouvant entraîner une consommation de bande passante plus importante, Chrome considère prerender comme un préchargement NoState.
  • +
  • <link rel="subresource"> {{non-standard_inline}} était pris en charge par Chrome par le passé et devait permettre de précharger les ressources pour le chargement et la navigation dans la page mais il n'existait de moyen de priorisation (l'attribut as n'existait pas) et l'ensemble des ressources recevait donc une priorité assez basse.
  • +
  • De nombreux utilitaires de chargement scriptés existent par ailleurs mais ils ne disposent pas du contexte de priorisation disponible dans le navigateur et, en tant que ressources, peuvent participer à ces problèmes de performances de chargement.
  • +
+ +

Spécifications

+ + + + + + + + + + + + + + + + + + + + + +
SpécificationStatutCommentaire
{{SpecName('Preload','#x2.link-type-preload','preload')}}{{Spec2('Preload')}}Détails complémentaires sur preload.
{{SpecName('HTML WHATWG', 'link-type-preload', 'rel=preload')}}{{Spec2('HTML WHATWG')}}Définition simple de preload.
+ +

Compatibilité des navigateurs

+ +

{{Compat("html.elements.link.rel.preload")}}

+ +

Voir aussi

+ + + +
{{QuickLinksWithSubpages("/fr/docs/Web/HTML")}}
-- cgit v1.2.3-54-g00ecf