From d596e86a4f13b04981f51d327af257b07e6d21c3 Mon Sep 17 00:00:00 2001 From: SphinxKnight Date: Sun, 14 Nov 2021 14:23:22 +0100 Subject: Prepare Learning Area section for Markdown conversion (#2738) * Remove summary, spans and fonts * Remove notranslate class * Remove ids other than headings * Remove hidden blocks * fix livesample call with exclamation mark * fix livesample call with exclamation mark * fix livesample call with exclamation mark * fix livesample call with exclamation mark * Fix notes * Remove code in pre, sub/sup and some styles * fix dls * fix absolute / english links * fix figures and others * fix other issues from report * Fix other one-off issues excl. imgs * Fix images * Fixes #2842 for Learning area --- .../learn/forms/advanced_form_styling/index.html | 132 ++- .../forms/basic_native_form_controls/index.html | 187 ++-- files/fr/learn/forms/form_validation/index.html | 269 +++-- .../example_1/index.html | 18 +- .../example_2/index.html | 4 +- .../example_3/index.html | 6 +- .../example_4/index.html | 6 +- .../example_5/index.html | 4 +- .../how_to_build_custom_form_controls/index.html | 66 +- .../how_to_structure_a_web_form/example/index.html | 2 +- .../forms/how_to_structure_a_web_form/index.html | 151 +-- .../forms/html_forms_in_legacy_browsers/index.html | 10 +- files/fr/learn/forms/index.html | 28 +- .../index.html | 1146 ++++++++++---------- .../sending_and_retrieving_form_data/index.html | 48 +- .../sending_forms_through_javascript/index.html | 10 +- files/fr/learn/forms/styling_web_forms/index.html | 30 +- .../learn/forms/your_first_form/example/index.html | 2 +- files/fr/learn/forms/your_first_form/index.html | 32 +- 19 files changed, 1056 insertions(+), 1095 deletions(-) (limited to 'files/fr/learn/forms') diff --git a/files/fr/learn/forms/advanced_form_styling/index.html b/files/fr/learn/forms/advanced_form_styling/index.html index b34fcc2065..040507b63e 100644 --- a/files/fr/learn/forms/advanced_form_styling/index.html +++ b/files/fr/learn/forms/advanced_form_styling/index.html @@ -1,20 +1,12 @@ --- title: Composition avancée des formulaires HTML slug: Learn/Forms/Advanced_form_styling -tags: - - Avancé - - CSS - - Exemple - - Formulaires - - Guide - - HTML - - Web translation_of: Learn/Forms/Advanced_form_styling original_slug: Web/Guide/HTML/Formulaires/Advanced_styling_for_HTML_forms ---
{{LearnSidebar}}{{PreviousMenuNext("Web/Guide/HTML/Formulaires/Apparence_des_formulaires_HTML", "Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_widgets", "Web/Guide/HTML/Formulaires")}}
-

Dans cet article, nous verrons comment utiliser les CSS avec les formulaires HTML pour modifier le style de certains widgets difficiles à personnaliser. Comme nous l'avons vu dans l'article précédent, les champs texte et les boutons sont parfaitement compatibles avec les CSS. Maintenant, nous allons approfondir la part sombre de la composition stylistique des formulaires HTML.

+

Dans cet article, nous verrons comment utiliser les CSS avec les formulaires HTML pour modifier le style de certains widgets difficiles à personnaliser. Comme nous l'avons vu dans l'article précédent, les champs texte et les boutons sont parfaitement compatibles avec les CSS. Maintenant, nous allons approfondir la part sombre de la composition stylistique des formulaires HTML.

Avant d'aller plus loin, faisons un rappel pour deux types de widgets de formulaires :

@@ -32,7 +24,7 @@ original_slug: Web/Guide/HTML/Formulaires/Advanced_styling_for_HTML_forms

L'évolution récente du HTML et des CSS a étendu l'expressivité des CSS :

-

Note : L'élément {{htmlelement("input")}} est spécial car il peut être pratiquement n'importe quoi. En réglant simplement ses attributs de type, il peut changer radicalement, et il est utilisé pour créer la plupart des types de widgets de formulaire allant des champs texte sur une seule ligne, contrôles sans entrée de texte, contrôles de date et heure jusqu'aux boutons. Il y a toutefois des exceptions, comme {{htmlelement("textarea")}} pour les entrées multi-lignes. Prenez bien note de ceci en lisant cet article.

+

Note : L'élément {{htmlelement("input")}} est spécial car il peut être pratiquement n'importe quoi. En réglant simplement ses attributs de type, il peut changer radicalement, et il est utilisé pour créer la plupart des types de widgets de formulaire allant des champs texte sur une seule ligne, contrôles sans entrée de texte, contrôles de date et heure jusqu'aux boutons. Il y a toutefois des exceptions, comme {{htmlelement("textarea")}} pour les entrées multi-lignes. Prenez bien note de ceci en lisant cet article.

 Champs texte sur une seule ligne

@@ -103,16 +103,16 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs

On crée un champ texte sur une seule ligne avec l'élément {{HTMLElement("input")}} dont l'attribut {{htmlattrxref("type", "input")}} est mis à text (maisi, si vous n'indiquez pas l'attribut {{htmlattrxref("type", "input")}}, text est la valeur par défaut). text est aussi la valeur de repli si celle indiquée pour l'attribut {{htmlattrxref("type", "input")}} est inconnue du navigateur (par exemple, si vous spécifiez type="date" et que le navigateur ne prend pas en charge les sélecteurs de date natifs).

-

Note : Vous trouverez des exemples de tous les types de champ texte sur une ligne dans GitHub à single-line-text-fields.html (voir directement aussi).

+

Note : Vous trouverez des exemples de tous les types de champ texte sur une ligne dans GitHub à single-line-text-fields.html (voir directement aussi).

Voici un exemple élémentaire de champ texte sur une ligne :

-
<input type="text" id="comment" name="comment" value="Je suis un champ texte">
+
<input type="text" id="comment" name="comment" value="Je suis un champ texte">

Les champs texte sur une ligne n'ont qu'une seule contrainte : si vous saisissez du texte avec des sauts de ligne, le navigateur les supprime avant d'envoyer les données.

-

Screenshots of single line text fields on several platforms.

+

Screenshots of single line text fields on several platforms.

HTML5 améliore le champ texte élémentaire sur une ligne par ajout de valeurs spéciales pour l'attribut {{htmlattrxref("type","input")}}. Ces valeurs conservent l'élément {{HTMLElement("input")}} en tant que champ texte sur une ligne mais ajoutent quelques contraintes et caractéristiques supplémentaires au champ.

@@ -120,25 +120,25 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs

Ce type de champ est défini en donnant la valeur email à l'attribut {{htmlattrxref("type","input")}} :

-
    <input type="email" id="email" name="email" multiple>
+
    <input type="email" id="email" name="email" multiple>

Avec ce type , l'utilisateur doit saisir un e‑mail valide dans le champ. Tout autre type de contenu amène le navigateur à émettre une erreur lors de la soumission du formulaire. Notez que cette validation s'opère côté client et est faite par le navigateur :

-

Entrée d'un e-mail non valide déclenchant un message d'avertissement « Veuillez saisir une adresse électronique valide »

+

Entrée d'un e-mail non valide déclenchant un message d'avertissement « Veuillez saisir une adresse électronique valide »

Avec l'attribut {{htmlattrxref("multiple","input")}}, l'utilisateur pourra saisir plusieurs adresses électroniques dans la même entrée (avec une virgule comme séparateur).

Sur certains périphériques (les mobiles en particulier), un clavier virtuel différent et mieux adapté à la saisie d'adresses électroniques peut être affiché.

-

Note: Vous trouverez plus de détails sur la validation des formulaires dans l'article Validation des données de formulaires.

+

Note : Vous trouverez plus de détails sur la validation des formulaires dans l'article Validation des données de formulaires.

Champ pour mot de passe

Ce type de champ est défini en donnant la valeur password à l'attribut {{htmlattrxref("type","input")}} :

-
    <input type="password" id="pwd" name="pwd">
+
    <input type="password" id="pwd" name="pwd">

Aucune contrainte de saisie du texte n'est ajoutée, mais la valeur entrée dans le champ est masquée (avec des points ou des astérisques) afin qu'elle ne puisse pas être lue par d'autres.

@@ -150,17 +150,17 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs

Ce type de champ se définit avec la valeur search de l'attribut {{htmlattrxref("type","input")}} :

-
    <input type="search" id="search" name="search">
+
    <input type="search" id="search" name="search">

La principale différence entre un champ textuel et un champ de recherche est dans l'apparence — souvent, les champs de recherche sont affichés avec des coins arrondis, et/ou avec une « × » à cliquer pour effacer la valeur entrée. Toutefois, une fonction est aussi ajoutée : les valeurs saisies peuvent être automatiquement enregistrées afin d'être utilisées pour compléter des recherches sur plusieurs pages du même site.

-

Screenshots of search fields on several platforms.

+

Screenshots of search fields on several platforms.

Champ pour numéro de téléphone

Ce type de champ se définit en donnant la valeur tel à l'attribut {{htmlattrxref("type","input")}} :

-
    <input type="tel" id="tel" name="tel">
+
    <input type="tel" id="tel" name="tel">

À cause de la grande variété de formats de numéros de téléphones à travers le monde, ce type de champ n'ajoute pas de contrainte à la valeur saisie par l'utilisateur. C'est principalement une différence sémantique, bien que sur certains appareils (notamment mobiles) un clavier virtuel différent, mieux adapté à la saisie de numéros de téléphone, puisse être présenté.

@@ -168,25 +168,27 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs

Ce type de champ se définit en donnant la valeur url à l'attribut {{htmlattrxref("type","input")}} :

-
    <input type="url" id="url" name="url">
+
    <input type="url" id="url" name="url">

Il ajoute une contrainte de validation spéciale du champ ; le navigateur renvoie une erreur si une URL invalide est saisie.

-
Note : ce n'est pas parce qu'une URL est bien formée qu'elle pointe vers un emplacement qui existe réellement.
+
+

Note : ce n'est pas parce qu'une URL est bien formée qu'elle pointe vers un emplacement qui existe réellement.

+
-

Note : La présence de champs avec contraintes spéciales considérés comme erronés bloquent l'envoi du formulaire. De plus, leur apparence peut être adaptée afin de mettre en évidence l'erreur. Nous allons discuter de cela dans l'article Validation de formulaires.

+

Note : La présence de champs avec contraintes spéciales considérés comme erronés bloquent l'envoi du formulaire. De plus, leur apparence peut être adaptée afin de mettre en évidence l'erreur. Nous allons discuter de cela dans l'article Validation de formulaires.

Champs texte multilignes

Un champ texte sur plusieurs lignes  se définit avec l'élément {{HTMLElement("textarea")}}, et non avec l'élément {{HTMLElement("input")}}.

-
    <textarea cols="30" rows="10"></textarea>
+
    <textarea cols="30" rows="10"></textarea>

La principale différence entre un champ textarea et un champ monoligne est que, dans un textarea, l'utilisateur peut saisir du texte avec des sauts de ligne en dur (c'est à dire en pressant la touche Retour).

-

Screenshots of multi-lines text fields on several platforms.

+

Screenshots of multi-lines text fields on several platforms.

Note : Vous trouverez un exemple de champ texte multiligne sur GitHub à l'adresse multi-line-text-field.html (voir aussi directement). Jetez-y un coup d'œil, et remarquez que dans la plupart des navigateurs, la zone de texte est dotée d'une poignée d'étirement en bas à droite pour permettre à l'utilisateur de la redimensionner. Cette capacité de redimensionnement peut être désactivée en réglant la propriété {{cssxref("resize")}} de la zone de texte à none dans les CSS.

@@ -239,7 +241,7 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs

Une boîte à sélection est créée avec l'élément {{HTMLElement("select")}} complétée d'un ou plusieurs éléments enfants {{HTMLElement("option")}} définissant les valeurs possibles.

-
    <select>
+
    <select>
       <option>Banane</option>
       <option>Cerise</option>
       <option>Citron</option>
@@ -247,7 +249,7 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs
 
 

Si nécessaire, la valeur par défaut de la boîte de sélection peut être définie en utilisant l'attribut {{htmlattrxref("selected","option")}} dans l'élément {{HTMLElement("option")}} désiré. Les éléments {{HTMLElement("option")}} peuvent être imbriqués dans des éléments {{HTMLElement("optgroup")}} pour créer des groupes de valeurs associées :

-
    <select>
+
    <select>
       <optgroup label="Fruits">
         <option>Banane</option>
         <option selected>Cerise</option>
@@ -260,7 +262,7 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs
       </optgroup>
     </select>
-

Screenshots of single line select box on several platforms.

+

Screenshots of single line select box on several platforms.

Si un élément {{HTMLElement("option")}} est défini avec l'attribut value, la valeur de cet attribut est envoyée lorsque le formulaire est soumis. Si l'attribut value est omis, le contenu de l'élément {{HTMLElement("option")}} est utilisé comme valeur de la boîte de sélection.

@@ -272,15 +274,17 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs

Dans ce cas toutefois, la boîte d'utilisateur n'affiche plus les valeurs sous forme d'un menu déroulant. Les valeurs sont toutes affichées dans une liste.

-
    <select multiple>
+
    <select multiple>
       <option>Banane</option>
       <option>Cerise</option>
       <option>Citron</option>
     </select>
-

Screenshots of multi-lines select box on several platforms.

+

Screenshots of multi-lines select box on several platforms.

-
Note : tous les navigateurs prenant en charge l'élément {{HTMLElement("select")}} prennent aussi en charge l'attribut {{htmlattrxref("multiple","select")}} sur lui.
+
+

Note : tous les navigateurs prenant en charge l'élément {{HTMLElement("select")}} prennent aussi en charge l'attribut {{htmlattrxref("multiple","select")}} sur lui.

+

Contenus auto-complétés

@@ -290,7 +294,7 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs

Une fois la liste de données affiliée au widget de formulaire, ses options s'utilisent comme complémentation du texte saisi par l'utilisateur ; cela se présente généralement à l'utilisateur sous forme d'une boîte déroulante listant des correspondances possibles avec ce qui doit être saisi dans la boîte.

-
    <label for="onFruit">Quel est votre fruit préféré ?</label>
+
    <label for="onFruit">Quel est votre fruit préféré ?</label>
     <input type="text" id="onFruit" list="maSuggestion" />
     <datalist id="maSuggestion">
       <option>Pomme</option>
@@ -303,9 +307,11 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs
       <option>Poire</option>
     </datalist>
-
Note : Selon la norme HTML, l'attribut {{htmlattrxref("list","input")}} et l'élément {{HTMLElement("datalist")}} peuvent s'utiliser avec tout type de widget nécessitant une saisie utilisateur. Toutefois, les modalités de ce fonctionnement ne sont pas claire pour des contrôles autres que textuels (de couleur ou de date par ex.) et les divers navigateurs se comporteront de manière différente selon le cas. Pour cette raison, soyez prudent en utilisant cette fonctionnalité avec autre chose que des champs textuels.
+
+

Note : Selon la norme HTML, l'attribut {{htmlattrxref("list","input")}} et l'élément {{HTMLElement("datalist")}} peuvent s'utiliser avec tout type de widget nécessitant une saisie utilisateur. Toutefois, les modalités de ce fonctionnement ne sont pas claire pour des contrôles autres que textuels (de couleur ou de date par ex.) et les divers navigateurs se comporteront de manière différente selon le cas. Pour cette raison, soyez prudent en utilisant cette fonctionnalité avec autre chose que des champs textuels.

+
-
Screenshots of datalist on several platforms.
+
Screenshots of datalist on several platforms.

Prise en charge de Datalist et recours

@@ -314,22 +320,22 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs

Pour gérer cela, voici une petite astuce offrant une bonne solution de repli pour ces navigateurs :

-
<label for="myFruit">Quel est votre fruit préféré ? (avec repli)</label>
-<input type="text" id="myFruit" name="fruit" list="fruitList">
-
-<datalist id="fruitList">
-  <label for="suggestion">ou choisissez un fruit</label>
-  <select id="suggestion" name="altFruit">
-    <option>Pomme</option>
-    <option>Banane</option>
-    <option>Mûres</option>
-    <option>Airelles</option>
-    <option>Citron</option>
-    <option>Litchi</option>
-    <option>Pêche</option>
-    <option>Poire</option>
-  </select>
-</datalist>
+
<label for="myFruit">Quel est votre fruit préféré ? (avec repli)</label>
+<input type="text" id="myFruit" name="fruit" list="fruitList">
+
+<datalist id="fruitList">
+  <label for="suggestion">ou choisissez un fruit</label>
+  <select id="suggestion" name="altFruit">
+    <option>Pomme</option>
+    <option>Banane</option>
+    <option>Mûres</option>
+    <option>Airelles</option>
+    <option>Citron</option>
+    <option>Litchi</option>
+    <option>Pêche</option>
+    <option>Poire</option>
+  </select>
+</datalist>

Les navigateurs qui prennent en charge l'élément {{HTMLElement("datalist")}} ignoreront tous les éléments qui ne sont pas {{HTMLElement("option")}} et fonctionneront comme prévu. D'autre part, les navigateurs qui ne prennent pas en charge l'élément {{HTMLElement("datalist")}} afficheront l'étiquette et la boîte de sélection. Bien sûr, il y a d'autres façons de gérer ce manque de prise en charge de l'élément {{HTMLElement("datalist")}}, mais c'est la manière la plus simple (d'autres ont besoin de JavaScript).

@@ -337,11 +343,11 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs Safari 6 - Screenshot of the datalist element fallback with Safari on Mac OS + Screenshot of the datalist element fallback with Safari on Mac OS Firefox 18 - Screenshot of the datalist element with Firefox on Mac OS + Screenshot of the datalist element with Firefox on Mac OS @@ -354,7 +360,7 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs

Il est important de noter que ces widgets ne se comportent pas tout à fait comme les autres widgets de formulaires. Pour la plupart des widgets, une fois que le formulaire est envoyé, tous les widgets dont l'attribut {{htmlattrxref("name","input")}} est défini sont envoyés, même s'ils ne sont pas renseignés. Dans le cas des éléments à cocher, leurs valeurs ne sont envoyées que s'ils sont cochés. S'ils ne sont pas cochés, rien n'est envoyé, pas même la valeur de leur attribut name.

-

Note : Vous trouverez les exemples de cette section sur GitHub à l'adresse checkable-items.html (voir directement aussi).

+

Note : Vous trouverez les exemples de cette section sur GitHub à l'adresse checkable-items.html (voir directement aussi).

Pour un maximum de convivialité/accessibilité, il est conseillé d'entourer chaque liste d'éléments liés dans un {{htmlelement("fieldset")}}, avec un élément {{htmlelement("legend")}} fournissant une description globale de la liste.  Chaque paire individuelle d'éléments {{htmlelement("label")}}/{{htmlelement("input")}} doit être contenue dans son propre élément de liste (ou similaire), comme le montrent les exemples.

@@ -365,22 +371,22 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs

Une casce à cocher se crée avec l'élément {{HTMLElement("input")}} dont l'attribut {{htmlattrxref("type","input")}} a pour valeur checkbox.

-
    <input type="checkbox" checked id="carrots" name="carrots" value="carrots">
+
    <input type="checkbox" checked id="carrots" name="carrots" value="carrots">
 

Mettre l'attribut checked fait que la case sera cochée au chargement de la page.

-

Screenshots of check boxes on several platforms.

+

Screenshots of check boxes on several platforms.

Bouton radio

Un bouton radio se crée avec un élément {{HTMLElement("input")}} dont l'attribut {{htmlattrxref("type","input")}} a la valeur radio.

-
    <input type="radio" checked id="soup" name="meal">
+
    <input type="radio" checked id="soup" name="meal">

Plusieurs boutons radio peuvent être liés ensemble. S'ils partagent la même valeur pour leur attribut {{htmlattrxref("name","input")}}, ils seront considérés comme faisant partie d'un seul groupe de boutons. Seulement un bouton à la fois peut être coché par groupe. Ceci signifie que si l'un d'entre eux est coché, tous les autres sont automatiquement décochés. Lorsque le formulaire est envoyé, seule la valeur du bouton coché est envoyée. Si aucun des boutons n'est coché, l'ensemble des boutons du groupe est considéré comme étant dans un état inconnu et aucune valeur n'est envoyée avec le formulaire.

-
<fieldset>
+
<fieldset>
   <legend>Quel est votre mets préféré ?</legend>
   <ul>
     <li>
@@ -396,9 +402,9 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs
       <input type="radio" id="pizza" name="meal" value="pizza">
     </li>
   </ul>
-</fieldset>
+</fieldset>
-

Screenshots of radio buttons on several platforms.

+

Screenshots of radio buttons on several platforms.

Boutons

@@ -417,7 +423,7 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs

submit

-
    <button type="submit">
+
    <button type="submit">
         Ceci est un <br><strong>bouton d'envoi</strong>
     </button>
 
@@ -425,7 +431,7 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs
 
 

reset

-
    <button type="reset">
+
    <button type="reset">
         Ceci est un <br><strong>bouton de réinitialisation</strong>
     </button>
 
@@ -433,7 +439,7 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs
 
 

anonymous

-
    <button type="button">
+
    <button type="button">
         Ceci est un <br><strong>bouton lambda</strong>
     </button>
 
@@ -446,7 +452,7 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs
  
  • Dans le cas des éléments {{HTMLElement("button")}}, il est possible d'avoir une valeur différente de l'étiquette du bouton (toutefois, ceci ne peut être utilisé pour les versions antérieures à la version 8 d'Internet Explorer).
  • -

    Screenshots of buttons on several platforms.

    +

    Screenshots of buttons on several platforms.

    Techniquement parlant, il n'y a pratiquement pas de différence entre un bouton défini avec l'élément {{HTMLElement("button")}} ou l'élément {{HTMLElement("input")}}. La seule différence à noter réside dans l'étiquette du bouton lui-même. Dans un élément {{HTMLElement("input")}}, l'étiquette ne peut être constituée que de données de type caractère, alors que dans un élément {{HTMLElement("button")}}, l'étiquette peut être mise sous HTML, de sorte qu'elle peut être mise en forme en conséquence.

    @@ -467,7 +473,7 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs

    Exemple

    -
        <input type="number" name="age" id="age" min="1" max="10" step="2">
    +
        <input type="number" name="age" id="age" min="1" max="10" step="2">

    Ceci créé un widget pour un nombre dont la valeur est comprise entre 1 et 10 et dont les boutons d'incrémentation/décrémentation modifient la valeur par pas de 2.

    @@ -479,29 +485,28 @@ original_slug: Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs

    Exemple

    -
        <input type="range" name="beans" id="beans" min="0" max="500" step="10">
    -
    +
    <input type="range" name="beans" id="beans" min="0" max="500" step="10">

    Cet exemple créé un curseur dont les valeurs varient entre 0 et 500, et dont les bouton d'incrément/décrément font varier la valeur de ±10.

    Un problème avec les curseurs est qu'il n'offrent aucun moyen visue de savoir quelle est leur valeur courante. Il est nécessaire d'ajouter cela vous‑même à l'aide de JavaScript, mais c'est assez facile. Dans cet exemple nous ajoutons un élément {{htmlelement("span")}} dans lequel nous écrivons la valeur courante du curseur et la mettons à jour quand elle est modifiée.

    -
    <label for="beans">Combien de haricots pouvez‑vous manger ?</label>
    -<input type="range" name="beans" id="beans" min="0" max="500" step="10">
    -<span class="beancount"></span>
    +
    <label for="beans">Combien de haricots pouvez‑vous manger ?</label>
    +<input type="range" name="beans" id="beans" min="0" max="500" step="10">
    +<span class="beancount"></span>

    et en  JavaScript :

    -
    var beans = document.querySelector('#beans');
    -var count = document.querySelector('.beancount');
    +
    var beans = document.querySelector('#beans');
    +var count = document.querySelector('.beancount');
     
    -count.textContent = beans.value;
    +count.textContent = beans.value;
     
    -beans.oninput = function() {
    -  count.textContent = beans.value;
    -}
    +beans.oninput = function() { + count.textContent = beans.value; +}
    -

    Ici nous stockons dans deux variables les références du curseur et celle de span, puis nous réglons immédiatement le textContent  de span à la valeur courante value de l'entrée. Enfin, nous avons mis en place un gestionnaire d'événements oninput de sorte que chaque fois que le curseur de plage est déplacé, le textContent de span est mis à jour avec la nouvelle valeur de l'entrée.

    +

    Ici nous stockons dans deux variables les références du curseur et celle de span, puis nous réglons immédiatement le textContent  de span à la valeur courante value de l'entrée. Enfin, nous avons mis en place un gestionnaire d'événements oninput de sorte que chaque fois que le curseur de plage est déplacé, le textContent de span est mis à jour avec la nouvelle valeur de l'entrée.

    L'attribut range pour input n'est pas pris en charge dans les versions d'Internet Explorer dont le numéro est inférieur à 10.

    @@ -515,32 +520,34 @@ beans.oninput <input type="datetime-local" name="datetime" id="datetime">
    +
    <input type="datetime-local" name="datetime" id="datetime">

    month

    Cette valeur d'attribut créé un widget pour afficher et sélectionner un mois dans une année donnée.

    -
    <input type="month" name="month" id="month">
    +
    <input type="month" name="month" id="month">

    time

    Cette valeur d'attribut créé un widget pour afficher et sélectionner un horaire.

    -
    <input type="time" name="time" id="time">
    +
    <input type="time" name="time" id="time">

    week

    Cette valeur d'attribut crée un widget pour afficher et sélectionner une semaine et l'année correspondante.

    -
    <input type="week" name="week" id="week">
    +
    <input type="week" name="week" id="week">

    Tous les contrôles de sélection de date et heure peuvent être contraints à l'aide des attributs {{htmlattrxref("min","input")}} et {{htmlattrxref("max","input")}}.

    -
        <label for="maDate">Quand êtes vous disponible cet été ?</label>
    +
        <label for="maDate">Quand êtes vous disponible cet été ?</label>
         <input type="date" min="2013-06-01" max="2013-08-31" id="maDate">
    -

    Attention : Les widgets de date et heure sont encore peu pris en charge. Au moment de la rédaction de cet article, Chrome, Edge et Opera les prennent bien en charge, mais il n'y a pas de prise en charge dans Internet Explorer et Firefox et Safari n'ont qu'une prise en charge lacunaire de ces derniers.

    +
    +

    Attention : Les widgets de date et heure sont encore peu pris en charge. Au moment de la rédaction de cet article, Chrome, Edge et Opera les prennent bien en charge, mais il n'y a pas de prise en charge dans Internet Explorer et Firefox et Safari n'ont qu'une prise en charge lacunaire de ces derniers.

    +

    Sélecteur de couleur

    @@ -548,7 +555,7 @@ beans.oninput color.

    -
    <input type="color" name="color" id="color">
    +
    <input type="color" name="color" id="color">

    Attention : la prise en charge du widget color n'est pas très bonne actuellement. Il n'y a aucune prise en charge dans Internet Explorer, ni actuellement dans Safari. Les autres navigateurs majeurs le prennent en charge.

    @@ -557,12 +564,12 @@ beans.oninput -

    Note : Vous trouverez les exemples de cette section sur GitHub à l'adresse other-examples.html (à voir aussi directement).

    +

    Note : Vous trouverez les exemples de cette section sur GitHub à l'adresse other-examples.html (à voir aussi directement).

    Sélection de fichier

    -

    Les formulaires HTML permettent d'envoyer des fichiers à un serveur. Cette action spécifique est détaillée dans l'article  « Envoi et extraction des données de formulaire ». Le widget de sélection de fichier permet à l'utilisateur de choisir un ou plusieurs fichiers à envoyer.

    +

    Les formulaires HTML permettent d'envoyer des fichiers à un serveur. Cette action spécifique est détaillée dans l'article  « Envoi et extraction des données de formulaire ». Le widget de sélection de fichier permet à l'utilisateur de choisir un ou plusieurs fichiers à envoyer.

    Pour créer un widget de sélection de fichier, vous devez utiliser un élément {{HTMLElement("input")}} dont l'attribut {{htmlattrxref("type","input")}} a pour valeur file. Les types de fichiers acceptés peuvent être contraints en utilisant l'attribut {{htmlattrxref("accept","input")}}. De plus, si vous souhaitez permettre à l'utilisateur de choisir plusieurs fichiers, vous pouvez le faire en ajoutant l'attribut {{htmlattrxref("multiple","input")}}.

    @@ -570,7 +577,7 @@ beans.oninput <input type="file" name="file" id="file" accept="image/*" multiple>
    +
    <input type="file" name="file" id="file" accept="image/*" multiple>

    Contenu caché

    @@ -578,7 +585,7 @@ beans.oninput <input type="hidden" id="timestamp" name="timestamp" value="1286705410">
    +
        <input type="hidden" id="timestamp" name="timestamp" value="1286705410">

    Image-bouton

    @@ -586,7 +593,7 @@ beans.oninput image. Cet élément accepte exactement le même ensemble d'attributs que l'élément {{HTMLElement("img")}}, en plus de tous les attributs valides pour n'importe quel bouton de formulaire.

    -
        <input type="image" alt="Click me!" src="my-img.png" width="80" height="30" />
    +
        <input type="image" alt="Click me!" src="my-img.png" width="80" height="30" />

    Si l'image-bouton est utilisée pour envoyer un formulaire, ce widget n'envoie pas sa valeur mais les coordonnées X et Y du clic sur l'image (les coordonnées sont relatives à l'image, ce qui veut dire que le coin supérieur gauche représente les coordonnées 0, 0). Les coordonnées sont envoyées sous la forme de deux paires de clé/valeur :

    @@ -597,9 +604,9 @@ beans.oninput http://foo.com?pos.x=123&pos.y=456
    +
        http://foo.com?pos.x=123&pos.y=456
    -

    C'est une façon très commode de construire une « hot map » (cartographie des parties d'une page Internet le plus souvent balayées par le regard des lecteurs). La manière d'envoyer et d'extraire ces valeurs est détaillée dans l'article « Envoi des données de formulaire ».

    +

    C'est une façon très commode de construire une « hot map » (cartographie des parties d'une page Internet le plus souvent balayées par le regard des lecteurs). La manière d'envoyer et d'extraire ces valeurs est détaillée dans l'article « Envoi des données de formulaire ».

    Compteurs et barres de progression

    @@ -609,7 +616,7 @@ beans.oninput -
        <progress max="100" value="75">75/100</progress>
    +
        <progress max="100" value="75">75/100</progress>

    Cela sert à mettre en œuvre visuellement un rapport d'avancement, comme le pourcentage du nombre total de fichiers téléchargés ou le nombre de questions posées dans un questionnaire.

    @@ -646,7 +653,7 @@ beans.oninput -
    <meter min="0" max="100" value="75" low="33" high="66" optimum="50">75</meter>
    +
    <meter min="0" max="100" value="75" low="33" high="66" optimum="50">75</meter>

    Le contenu de l'élément {{HTMLElement("meter")}} est un affichage informatif de repli pour les navigateurs ne prenant pas en charge cet élément ; les technologies d'assistance vocalisent cet affichage.

    @@ -671,7 +678,7 @@ beans.oninput Mon premier formulaire HTML -
  • Comment structurer un formulaire HTML
  • +
  • Comment structurer un formulaire HTML
  • Les widgets natifs pour formulaire
  • Envoi des données de formulaire
  • Validation des données de formulaire
  • diff --git a/files/fr/learn/forms/form_validation/index.html b/files/fr/learn/forms/form_validation/index.html index 137b1be959..b95ce27d09 100644 --- a/files/fr/learn/forms/form_validation/index.html +++ b/files/fr/learn/forms/form_validation/index.html @@ -1,26 +1,18 @@ --- title: Validation des données de formulaires slug: Learn/Forms/Form_validation -tags: - - Exemple - - Formulaires - - Guide - - HTML - - Intermédiaire - - JavaScript - - Web translation_of: Learn/Forms/Form_validation original_slug: Web/Guide/HTML/Formulaires/Validation_donnees_formulaire ---
    {{LearnSidebar}}{{PreviousMenuNext("Web/Guide/HTML/Formulaires/Envoyer_et_extraire_les_données_des_formulaires", "Web/Guide/HTML/Formulaires/Comment_construire_des_widgets_de_formulaires_personnalisés", "Web/Guide/HTML/Formulaires")}}
    -

    Ce n'est pas tout d'envoyer des données — il faut aussi s'assurer que les données mises dans un formulaire par un utilisateur sont dans un format correct pour pouvoir être traitées correctement et qu'elles ne vont pas casser nos applications. Nous voulons également aider les utilisateurs à compléter les formulaires correctement et à ne pas ressentir de frustration en essayant d'utiliser les applications. La validation des données de formulaire vous aide à remplir ces objectifs — cet article indique ce qu'il est nécessaire de savoir.

    +

    Ce n'est pas tout d'envoyer des données — il faut aussi s'assurer que les données mises dans un formulaire par un utilisateur sont dans un format correct pour pouvoir être traitées correctement et qu'elles ne vont pas casser nos applications. Nous voulons également aider les utilisateurs à compléter les formulaires correctement et à ne pas ressentir de frustration en essayant d'utiliser les applications. La validation des données de formulaire vous aide à remplir ces objectifs — cet article indique ce qu'il est nécessaire de savoir.

    - +
    - + @@ -56,7 +48,7 @@ original_slug: Web/Guide/HTML/Formulaires/Validation_donnees_formulaire

    Vous rencontrerez différents types de validation de formulaires sur le Web :

    -
      +
      • La validation côté client est la validation qui est effectuée dans le navigateur, avant que les données n'aient été soumises au serveur. Cette méthode est plus conviviale que la validation côté serveur car elle donne une réponse instantanée. Il est possible de la subdiviser encore avec :
        • la validation JavaScript, codée en JavaScript, entièrement personnalisable.
        • @@ -76,7 +68,7 @@ original_slug: Web/Guide/HTML/Formulaires/Validation_donnees_formulaire

          Utiliser la validation intégrée au formulaire

          -

          Une des caractéristiques de HTML5 est la possibilité de valider la plupart des données utilisateur sans avoir recours à des scripts. Ceci se fait en utilisant des attributs de validation sur les éléments de formulaire ; ils vous permettent de spécifier des règles pour une entrée de formulaire comme : une valeur doit‑elle être remplie ? y a-t-il une longueur minimale et/ou maximale des données ? doit‑elle être un nombre, une adresse e-mail ou autre chose ? doit‑elle correspondre à un modèle ? Si les données saisies suivent toutes ces règles, elles sont considérées comme valides ; si ce n'est pas le cas, elles sont considérées comme non valides.
          +

          Une des caractéristiques de HTML5 est la possibilité de valider la plupart des données utilisateur sans avoir recours à des scripts. Ceci se fait en utilisant des attributs de validation sur les éléments de formulaire ; ils vous permettent de spécifier des règles pour une entrée de formulaire comme : une valeur doit‑elle être remplie ? y a-t-il une longueur minimale et/ou maximale des données ? doit‑elle être un nombre, une adresse e-mail ou autre chose ? doit‑elle correspondre à un modèle ? Si les données saisies suivent toutes ces règles, elles sont considérées comme valides ; si ce n'est pas le cas, elles sont considérées comme non valides.
          Quand un élément est valide :

            @@ -91,37 +83,31 @@ original_slug: Web/Guide/HTML/Formulaires/Validation_donnees_formulaire
          • si l'utilisateur essaie d'envoyer le formulaire, le navigateur le bloquera et affichera un message d'erreur.
          -

          Contraintes de validation sur les éléments d'entrée — simple début

          - - +

          Contraintes de validation sur les éléments input — simple début

          Dans cette section, nous examinerons quelques unes des diverses fonctionnalités HTML5 peuvant être utilisées pour valider des éléments d'{{HTMLElement("input")}}.

          Commençons par un exemple simple — une entrée ouvrant un choix, selon votre préférence, entre banane ou cerise. Il faut un texte {{HTMLElement("input")}} simple avec une étiquette correspondante et un {{htmlelement("button")}} de soumission. Le code source est sur GitHub à l'adresse fruit-start.html et un exemple « live » ci-dessous :

          - -

          {{EmbedLiveSample("Hidden_code", "100%", 55)}}

          +

          {{EmbedLiveSample("Contraintes_de_validation_sur_les_éléments_input_—_simple_début", "100%", 55)}}

          Pour commencer, faites une copie de fruit-start.html dans un nouveau répertoire sur votre disque dur.

          -

          L'attribut required

          +

          Attribut required

          La fonctionnalité de validation HTML5 la plus simple à utiliser est l'attribut {{htmlattrxref("required", "input")}}} — si vous voulez rendre une entrée obligatoire, vous pouvez marquer l'élément en utilisant cet attribut. Lorsque cet attribut est mis, le formulaire ne sera pas soumis (et affichera un message d'erreur) si l'entrée est vide (l'entrée sera également considérée comme invalide).

          @@ -145,11 +131,11 @@ input:valid {

          L'entrée a une bordure en pointillés rouge vif lorsqu'elle n'est pas valide, et une bordure noire plus subtile lorsqu'elle est valide. Essayez le nouveau comportement dans l'exemple ci-dessous :

          -

          {{EmbedLiveSample("L'attribut_required", "100%", 55)}}

          +

          {{EmbedLiveSample("Attribut_required", "100%", 55)}}

          Validation selon une expression régulière

          -

          Une autre fonctionnalité de validation très courante est l'attribut {{htmlattrxref("pattern", "input")}}, qui attend une expression régulière comme valeur. Une expression régulière (regex) est un modèle qui peut être utilisé pour faire correspondre des combinaisons de caractères dans des chaînes de texte, de sorte qu'elles sont idéales pour la validation de formulaires (ainsi que diverses autres utilisations en JavaScript). Les Regex sont assez complexes et nous n'avons pas l'intention de vous les enseigner de manière exhaustive dans cet article.

          +

          Une autre fonctionnalité de validation très courante est l'attribut {{htmlattrxref("pattern", "input")}}, qui attend une expression régulière comme valeur. Une expression régulière (regex) est un modèle qui peut être utilisé pour faire correspondre des combinaisons de caractères dans des chaînes de texte, de sorte qu'elles sont idéales pour la validation de formulaires (ainsi que diverses autres utilisations en JavaScript). Les Regex sont assez complexes et nous n'avons pas l'intention de vous les enseigner de manière exhaustive dans cet article.

          Vous trouverez ci-dessous quelques exemples pour vous donner une idée de base de leur fonctionnement :

          @@ -184,21 +170,19 @@ input:valid {

          Voyons un exemple — mettons à jour notre HTML en y ajoutant un attribut pattern, ainsi :

          -
          <form>
          +
          <form>
             <label for="choose">Préférez‑vous la banane ou la cerise ?</label>
             <input id="choose" name="i_like" required pattern="banane|cerise">
             <button>Soumettre</button>
          -</form>
          +</form>
          - +}

          {{EmbedLiveSample("Validation_selon_une_expression_régulière", "100%", 55)}}

          @@ -211,7 +195,7 @@ input:valid {
          -

          Note : L'élément {{HTMLElement("textarea")}} ne prend pas en charge l'attribut {{htmlattrxref("pattern", "input")}}.

          +

          Note : L'élément {{HTMLElement("textarea")}} ne prend pas en charge l'attribut {{htmlattrxref("pattern", "input")}}.

          Limitation de la taille des entrées

          @@ -224,7 +208,7 @@ input:valid {

          Supprimez maintenant le contenu de l'élément <body> et remplacez-le par le suivant :

          -
          <form>
          +
          <form>
             <div>
               <label for="choose">Préférez‑vous la banane ou la cerise ?</label>
               <input id="choose" name="i_like" required minlength="6" maxlength="6">
          @@ -236,15 +220,14 @@ input:valid {
             <div>
               <button>Soumettre</button>
             </div>
          -</form>
          +</form>
          • Ici, nous avons donné au champ de texte une taille minimale et maximale de 6 caractères — la même que celle de banane ou cerise. La saisie de moins de 6 caractères s'affichera comme non valide et la saisie de plus de 6 caractères ne sera pas possible dans la plupart des navigateurs.
          • Nous avons également contraint le champ number à un min de 1 et un max de 10 — les nombres entrés hors de cette plage seront affichés comme non valides, et vous ne pourrez pas utiliser les flèches d'incrémentation/décrémentation pour porter la valeur en dehors de cette plage.
          - +}

          Voici cet exemple s'exécutant en « live » :

          {{EmbedLiveSample('Limitation_de_la_taille_des_entrées', "100%", 100)}}

          -

          Note: <input type="number"> (et d'autres types, comme range) acceptent aussi un attribut {{htmlattrxref("step", "input")}} qui spécifie l'incrément en plus ou en moins de la valeur quand les contrôles d'entrée sont utilisés (comme les boutons ^ et v).

          +

          Note : <input type="number"> (et d'autres types, comme range) acceptent aussi un attribut {{htmlattrxref("step", "input")}} qui spécifie l'incrément en plus ou en moins de la valeur quand les contrôles d'entrée sont utilisés (comme les boutons ^ et v).

          Exemple complet

          Voici un exemple complet montrant l'utilisation des fonctionnalités HTML intégrées pour la validation :

          -
          <form>
          -  <p>
          -    <fieldset>
          -      <legend>Qualité<abbr title="Ce champ est obligatoire">*</abbr></legend>
          -      <input type="radio" required name="title" id="r1" value="Mr"><label for="r1">M.</label>
          -      <input type="radio" required name="title" id="r2" value="Ms"><label for="r2">Mme.</label>
          -    </fieldset>
          -  </p>
          -  <p>
          -    <label for="n1">Quel est votre âge ?</label>
          -    <!-- L'attribut pattern peut servir de recours pour les navigateurs dont le type number n'est
          +
          <form>
          +  <p>
          +    <fieldset>
          +      <legend>Qualité<abbr title="Ce champ est obligatoire">*</abbr></legend>
          +      <input type="radio" required name="title" id="r1" value="Mr"><label for="r1">M.</label>
          +      <input type="radio" required name="title" id="r2" value="Ms"><label for="r2">Mme.</label>
          +    </fieldset>
          +  </p>
          +  <p>
          +    <label for="n1">Quel est votre âge ?</label>
          +    <!-- L'attribut pattern peut servir de recours pour les navigateurs dont le type number n'est
                    pas implémenté pour input mais qui prennent en charge l'attribut pattern. Veuillez noter
                    que les navigateurs prenant en charge l'attribut pattern ne signalent pas d'erreur quand
          -         il est utilisé avec un champ number. Seule son utilisation ici agit en tant que recours. -->
          -    <input type="number" min="12" max="120" step="1" id="n1" name="age"
          -           pattern="\d+">
          -  </p>
          -  <p>
          -    <label for="t1">Quel est votre fruit favori ?<abbr title="Ce champ est obligatoire">*</abbr></label>
          -    <input type="text" id="t1" name="fruit" list="l1" required
          -           pattern="[Bb]anane|[Cc]erise|[Cc]itron|[Ff]raise|[Oo]range|[Pp]omme">
          -    <datalist id="l1">
          -      <option>Banane</option>
          -      <option>Cerise</option>
          -      <option>Citron</option>
          -      <option>Fraise</option>
          -      <option>Orange</option>
          -      <option>Pomme</option>
          -    </datalist>
          -  </p>
          -  <p>
          -    <label for="t2">Quelle est votre adresse électronique ?</label>
          -    <input type="email" id="t2" name="email">
          -  </p>
          -  <p>
          -    <label for="t3">Laissez un court message</label>
          -    <textarea id="t3" name="msg" maxlength="140" rows="5"></textarea>
          -  </p>
          -  <p>
          -    <button>Soumettre</button>
          -  </p>
          -</form>
          - -
          body {
          -  font: 1em sans-serif;
          -  padding: 0;
          -  margin : 0;
          -}
          -
          -form {
          -  max-width: 300px;
          -  margin: 0;
          -  padding: 0 5px;
          -}
          -
          -p > label {
          -  display: block;
          -}
          -
          -input[type=text],
          +         il est utilisé avec un champ number. Seule son utilisation ici agit en tant que recours. -->
          +    <input type="number" min="12" max="120" step="1" id="n1" name="age"
          +           pattern="\d+">
          +  </p>
          +  <p>
          +    <label for="t1">Quel est votre fruit favori ?<abbr title="Ce champ est obligatoire">*</abbr></label>
          +    <input type="text" id="t1" name="fruit" list="l1" required
          +           pattern="[Bb]anane|[Cc]erise|[Cc]itron|[Ff]raise|[Oo]range|[Pp]omme">
          +    <datalist id="l1">
          +      <option>Banane</option>
          +      <option>Cerise</option>
          +      <option>Citron</option>
          +      <option>Fraise</option>
          +      <option>Orange</option>
          +      <option>Pomme</option>
          +    </datalist>
          +  </p>
          +  <p>
          +    <label for="t2">Quelle est votre adresse électronique ?</label>
          +    <input type="email" id="t2" name="email">
          +  </p>
          +  <p>
          +    <label for="t3">Laissez un court message</label>
          +    <textarea id="t3" name="msg" maxlength="140" rows="5"></textarea>
          +  </p>
          +  <p>
          +    <button>Soumettre</button>
          +  </p>
          +</form>
          + +
          body {
          +  font: 1em sans-serif;
          +  padding: 0;
          +  margin : 0;
          +}
          +
          +form {
          +  max-width: 300px;
          +  margin: 0;
          +  padding: 0 5px;
          +}
          +
          +p > label {
          +  display: block;
          +}
          +
          +input[type=text],
           input[type=email],
           input[type=number],
           textarea,
          -fieldset {
          -/* requis pour composer de manière appropriée les éléments
          -   de formulaire sur les navigateurs fondés sur WebKit */
          -  -webkit-appearance: none;
          +fieldset {
          +/* requis pour composer de manière appropriée les éléments
          +   de formulaire sur les navigateurs fondés sur WebKit */
          +  -webkit-appearance: none;
           
          -  width : 100%;
          -  border: 1px solid #333;
          -  margin: 0;
          +  width : 100%;
          +  border: 1px solid #333;
          +  margin: 0;
           
          -  font-family: inherit;
          -  font-size: 90%;
          +  font-family: inherit;
          +  font-size: 90%;
           
          -  -moz-box-sizing: border-box;
          -  box-sizing: border-box;
          -}
          +  -moz-box-sizing: border-box;
          +  box-sizing: border-box;
          +}
           
          -input:invalid {
          -  box-shadow: 0 0 5px 1px red;
          -}
          +input:invalid {
          +  box-shadow: 0 0 5px 1px red;
          +}
           
          -input:focus:invalid {
          -  outline: none;
          -}
          +input:focus:invalid { + outline: none; +}

          {{EmbedLiveSample("Exemple_complet", "100%", 450)}}

          -

          Messages d'erreur personnalisés

          +

          Messages adaptés pour les erreurs

          Comme nous avons vu dans les exemples précédents, à chaque fois qu'un utilisateur tente d'envoyer un formulaire invalide, le navigateur affiche un message d'erreur. La manière dont le message est affiché dépend du navigateur.

          @@ -382,22 +364,22 @@ fieldset {
    - + - + - +
    Prérequis :Notions concernant les ordinateurs, une bonne compréhension du HTML, des CSS et de JavaScript.Notions concernant les ordinateurs, une bonne compréhension du HTML, des CSS et de JavaScript.
    Objectif :
    Firefox 17 (Windows 7)Example of an error message with Firefox in French on an English pageExample of an error message with Firefox in French on an English page
    Chrome 22 (Windows 7)Example of an error message with Chrome in French on an English pageExample of an error message with Chrome in French on an English page
    Opera 12.10 (Mac OSX)Example of an error message with Opera in French on an English pageExample of an error message with Opera in French on an English page

    Pour personnaliser l'apparence et le texte de ces messages, vous devez utiliser JavaScript ; il n'est pas possible de l'implémenter en utilisant uniquement HTML et CSS.

    -

    HMTL5 fournit une API de contraintes de validation pour vérifier et personnaliser l'état des élément d'un formulaire. Il est possible, entre autres, de changer le texte des messages d'erreur. Voici un court exemple :

    +

    HMTL5 fournit une API de contraintes de validation pour vérifier et personnaliser l'état des élément d'un formulaire. Il est possible, entre autres, de changer le texte des messages d'erreur. Voici un court exemple :

    <form>
       <label for="mail">Pourriez-vous nous fournir une adresse mail ?</label>
    @@ -405,7 +387,7 @@ fieldset {
       <button>Envoyer</button>
     </form>
    -

    En JavaScript, il faut appeler la méthode setCustomValidity():

    +

    En JavaScript, il faut appeler la méthode setCustomValidity():

    var email = document.getElementById("mail");
     
    @@ -417,7 +399,7 @@ email.addEventListener("keyup", function (event) {
       }
     });
    -

    {{EmbedLiveSample("Messages_d'erreur_personnalisés", "100%", 50)}}

    +

    {{EmbedLiveSample("Messages_adaptés_pour_les_erreurs", "100%", 50)}}

    Validation de formulaires avec JavaScript

    @@ -511,7 +493,7 @@ email.addEventListener("keyup", function (event) {

    Pour les anciens navigateurs, il existe une prothèse d'émulation (polyfill) comme Hyperform, pour compenser le défaut de prise en charge de cette API. Comme vous utilisez déjà JavaScript, l'utilisation d'une prethèse d'émulation n'est pas un souci supplémentaire pour la conception ou l'implémentation de votre site ou application Web.

    -

    Exemple d'utilisation de l'API de validation des contraintes

    +

    Exemple utilisant la validation des contraintes

    Voyons comment utiliser l'API pour créer des messages d'erreur personnalisés. Tout d'abord, le HTML :

    @@ -528,7 +510,7 @@ email.addEventListener("keyup", function (event) {

    Ce formulaire simple utilise l'attribut {{htmlattrxref("novalidate","form")}} pour désactiver la validation automatique par le navigateur ; cela permet donc à notre script d'avoir le contrôle sur la validation. Toutefois, cela ne désactive la prise en charge par l'API de validation des contraintes, ni l'application des pseudo-classes CSS  {{cssxref(":valid")}}, {{cssxref(":invalid")}}, {{cssxref(":in-range")}} et {{cssxref(":out-of-range")}}. Cela signifie que, même si le navigateur ne vérifie pas automatiquement la validité du formulaire avant l'envoi des données, vous pouvez toujours effectuer cette validation et définir l'apparence du formulaire par vous-même.

    -

    L'attribut aria-live garantit que nos messages d'erreur personnalisés seront affichés à tout le monde, y compris les personnes utilisant des techniques d'assistance comme des lecteurs d'écran.

    +

    L'attribut aria-live garantit que nos messages d'erreur personnalisés seront affichés à tout le monde, y compris les personnes utilisant des techniques d'assistance comme des lecteurs d'écran.

    CSS
    @@ -628,7 +610,7 @@ form.addEventListener("submit", function (event) {

    Voici le résultat:

    -

    {{EmbedLiveSample("Exemple_d'utilisation_de_l'API_de_validation_des_contraintes", "100%", 130)}}

    +

    {{EmbedLiveSample("Exemple_utilisant_la_validation_des_contraintes", "100%", 130)}}

    L'API de validation des contraintes fournit un outil puissant pour gérer la validation des formulaires, en vous laissant un contrôle sur l'interface utilisateur bien supérieur à ce que vous auriez pu avoir avec uniquement HTML et CSS. 

    @@ -644,18 +626,17 @@ form.addEventListener("submit", function (event) {
    Que dois-je faire si le formulaire n'est pas valide ?
    C'est clairement une affaire d'interface utilisateur. Vous devez décider comment le formulaire doit se comporter : enverra-t-il quand même les données ? Devriez-vous mettre en évidence les champs qui sont en erreur ? Devriez-vous afficher des messages d'erreur ?
    Comment puis-je aider l'utilisateur à corriger ses données invalides?
    -
    Pour limiter la frustration de l'utilisateur, il est très important de fournir autant d'information d'aide que nécessaire pour le guider dans la correction de sa saisie. Vous devriez afficher des suggestions en amont pour que l'utilisateur sache ce qui est attendu, ainsi que des messages d'erreur clairs. Si vous souhaitez vous plonger dans les exigences d'interface utilsateur pour la validation de formulaires, voici quelques articles (en anglais) utiles que vous devriez lire :
    -
    +

    Pour limiter la frustration de l'utilisateur, il est très important de fournir autant d'information d'aide que nécessaire pour le guider dans la correction de sa saisie. Vous devriez afficher des suggestions en amont pour que l'utilisateur sache ce qui est attendu, ainsi que des messages d'erreur clairs. Si vous souhaitez vous plonger dans les exigences d'interface utilsateur pour la validation de formulaires, voici quelques articles (en anglais) utiles que vous devriez lire :

    -

    Exemple qui n'utilise pas l'API de validation des contraintes

    +

    Exemple sans utilisation de la validation des contraintes

    Afin d'illustrer le propos, réécrivons le précédent exemple afin qu'il fonctionne avec d'anciens navigateurs:

    @@ -672,7 +653,7 @@ form.addEventListener("submit", function (event) { <button type="submit">Envoyer</button> </form>
    -

    Comme vous pouvez voir, le HTML est quasiment identique; nous avons juste enlevé les fonctionnalités de validation HTML. Notez que ARIA est une spécification indépendante qui n'est pas spécifiquement liée à HTML5.

    +

    Comme vous pouvez voir, le HTML est quasiment identique; nous avons juste enlevé les fonctionnalités de validation HTML. Notez que ARIA est une spécification indépendante qui n'est pas spécifiquement liée à HTML5.

    CSS
    @@ -818,7 +799,7 @@ addEvent(form, "submit", function () {

    Voici le résultat:

    -

    {{EmbedLiveSample("Exemple_qui_n'utilise_pas_l'API_de_validation_des_contraintes", "100%", 130)}}

    +

    {{EmbedLiveSample("Exemple_sans_utilisation_de_la_validation_des_contraintes", "100%", 130)}}

    Comme vous avez pu le voir, il n'est pas si difficile de créer par soi-même un système de validation. La difficulté consiste à rendre le tout assez générique pour l'utiliser à la fois sur toutes les plateformes et pour chaque formulaire que vous pourriez créer. Il existe de nombreuses bibliothèques permettant ce genre de validation de formulaire ; n'hésitez pas à les utiliser. En voici quelques exemples :

    @@ -830,7 +811,7 @@ addEvent(form, "submit", function () {
  • Greffons jQuery :
  • @@ -861,15 +842,15 @@ addEvent(form, "submit", function () {

    Dans ce module

    diff --git a/files/fr/learn/forms/how_to_build_custom_form_controls/example_1/index.html b/files/fr/learn/forms/how_to_build_custom_form_controls/example_1/index.html index e488687b73..20e96ebc26 100644 --- a/files/fr/learn/forms/how_to_build_custom_form_controls/example_1/index.html +++ b/files/fr/learn/forms/how_to_build_custom_form_controls/example_1/index.html @@ -11,9 +11,9 @@ original_slug: >- ---

    C'est le premier exemple de code qui explique comment construire un widget de formulaire personnalisé.

    -

    État initial

    +

    État initial

    -

    HTML

    +

    HTML

    <div class="select">
       <span class="value">Cerise</span>
    @@ -26,7 +26,7 @@ original_slug: >-
       </ul>
     </div>
    -

    CSS

    +

    CSS

    /* --------------- */
     /* Styles Requis   */
    @@ -148,9 +148,9 @@ original_slug: >-
     
     
    {{ EmbedLiveSample("Basic_state", 120, 130) }}
    -

    État actif

    +

    État actif

    -

    HTML

    +

    HTML

    <div class="select active">
       <span class="value">Cerise</span>
    @@ -163,7 +163,7 @@ original_slug: >-
       </ul>
     </div>
    -

    CSS

    +

    CSS

    /* --------------- */
     /* Styles Requis   */
    @@ -284,9 +284,9 @@ original_slug: >-
     
     
    {{ EmbedLiveSample("Active_state", 120, 130) }}
    -

    État ouvert

    +

    État ouvert

    -

    HTML

    +

    HTML

    <div class="select active">
       <span class="value">Cerise</span>
    @@ -299,7 +299,7 @@ original_slug: >-
       </ul>
     </div>
    -

    CSS

    +

    CSS

    /* --------------- */
     /* Styles Requis   */
    diff --git a/files/fr/learn/forms/how_to_build_custom_form_controls/example_2/index.html b/files/fr/learn/forms/how_to_build_custom_form_controls/example_2/index.html
    index b70d286010..ac248a0470 100644
    --- a/files/fr/learn/forms/how_to_build_custom_form_controls/example_2/index.html
    +++ b/files/fr/learn/forms/how_to_build_custom_form_controls/example_2/index.html
    @@ -10,7 +10,7 @@ original_slug: >-
     ---
     

    Ceci est le deuxième exemple expliquant comment construire un formulaire personnalisé.

    -

    JS

    +

    JS

    HTML Content

    @@ -174,7 +174,7 @@ original_slug: >-

    {{ EmbedLiveSample('JS', 120, 130) }}

    -

    Sans JS

    +

    Sans JS

    HTML Content

    diff --git a/files/fr/learn/forms/how_to_build_custom_form_controls/example_3/index.html b/files/fr/learn/forms/how_to_build_custom_form_controls/example_3/index.html index 5140b97c20..2967d9d181 100644 --- a/files/fr/learn/forms/how_to_build_custom_form_controls/example_3/index.html +++ b/files/fr/learn/forms/how_to_build_custom_form_controls/example_3/index.html @@ -8,9 +8,9 @@ translation_of: Learn/Forms/How_to_build_custom_form_controls/Example_3 original_slug: >- Web/Guide/HTML/Formulaires/Comment_construire_des_widgets_de_formulaires_personnalisés/Example_3 --- -

    Ceci est le troisième exemple expliquant comment construire des widgets de formulaire personnalisés.

    +

    Ceci est le troisième exemple expliquant comment construire des widgets de formulaire personnalisés.

    -

    Changement d'état

    +

    Changement d'état

    Contenu HTML

    @@ -245,4 +245,4 @@ window.addEventListener('load', function () {

    Résultat

    -

    {{ EmbedLiveSample('Change_states') }}

    +

    {{ EmbedLiveSample('Changement_détat') }}

    diff --git a/files/fr/learn/forms/how_to_build_custom_form_controls/example_4/index.html b/files/fr/learn/forms/how_to_build_custom_form_controls/example_4/index.html index e1d738ee61..dc6f31576c 100644 --- a/files/fr/learn/forms/how_to_build_custom_form_controls/example_4/index.html +++ b/files/fr/learn/forms/how_to_build_custom_form_controls/example_4/index.html @@ -12,9 +12,9 @@ translation_of: Learn/Forms/How_to_build_custom_form_controls/Example_4 original_slug: >- Web/Guide/HTML/Formulaires/Comment_construire_des_widgets_de_formulaires_personnalisés/Example_4 --- -

    Ceci est le quatrième exemple expliquant comment construire des widgets de formulaire personnalisés.

    +

    Ceci est le quatrième exemple expliquant comment construire des widgets de formulaire personnalisés.

    -

    Changement d'état

    +

    Changement d'état

    Contenu HTML

    @@ -295,4 +295,4 @@ window.addEventListener('load', function () {

    Résultat

    -

    {{ EmbedLiveSample('Change_states') }}

    +

    {{ EmbedLiveSample('Changement_détat') }}

    diff --git a/files/fr/learn/forms/how_to_build_custom_form_controls/example_5/index.html b/files/fr/learn/forms/how_to_build_custom_form_controls/example_5/index.html index aad371bc78..caf65d51c3 100644 --- a/files/fr/learn/forms/how_to_build_custom_form_controls/example_5/index.html +++ b/files/fr/learn/forms/how_to_build_custom_form_controls/example_5/index.html @@ -10,7 +10,7 @@ original_slug: >- ---

    Voici le dernier exemple expliquant comment construire des widgets de formulaire personnalisés.

    -

    Changement d'état

    +

    Changement d'état

    Contenu HTML

    @@ -288,4 +288,4 @@ window.addEventListener('load', function () {

    Résultat

    -

    {{ EmbedLiveSample('Change_states') }}

    +

    {{ EmbedLiveSample('Changement_détat') }}

    diff --git a/files/fr/learn/forms/how_to_build_custom_form_controls/index.html b/files/fr/learn/forms/how_to_build_custom_form_controls/index.html index b97d14b86e..ed842a9e47 100644 --- a/files/fr/learn/forms/how_to_build_custom_form_controls/index.html +++ b/files/fr/learn/forms/how_to_build_custom_form_controls/index.html @@ -14,12 +14,12 @@ original_slug: >- ---
    {{LearnSidebar}}{{PreviousMenuNext("Web/Guide/HTML/Formulaires/Validation_donnees_formulaire", "Web/Guide/HTML/Formulaires/Sending_forms_through_JavaScript", "Web/Guide/HTML/Formulaires")}}
    -

    Dans de nombreux cas les widgets de formulaires HTML disponibles ne suffisent pas. Si vous voulez composer certains widgets dans un style avancé tels que l'élément {{HTMLElement("select")}} ou si vous voulez leur donner des comportements personnalisés, vous n'avez pas d'autre choix que de créer vos propres widgets.

    +

    Dans de nombreux cas les widgets de formulaires HTML disponibles ne suffisent pas. Si vous voulez composer certains widgets dans un style avancé tels que l'élément {{HTMLElement("select")}} ou si vous voulez leur donner des comportements personnalisés, vous n'avez pas d'autre choix que de créer vos propres widgets.

    Dans cet article, nous verrons comment construire un tel widget. Pour cela, nous allons travailler avec un exemple : reconstruire l'élément {{HTMLElement("select")}}.

    -

    Note : Nous nous resterons centrés sur la construction des widgets, et non sur la façon de rendre le code générique et réutilisable ; cela impliquerait une manipulation de code JavaScript et de DOM dans un contexte inconnu, et nous sortirions de la portée de cet article.

    +

    Note : Nous nous resterons centrés sur la construction des widgets, et non sur la façon de rendre le code générique et réutilisable ; cela impliquerait une manipulation de code JavaScript et de DOM dans un contexte inconnu, et nous sortirions de la portée de cet article.

    Conception, structure et sémantique

    @@ -28,58 +28,46 @@ original_slug: >-

    Dans notre exemple, nous allons reconstruire l'élément {{HTMLElement("select")}}}. Voici le résultat que nous voulons atteindre :

    -

    The three states of a select box

    +

    The three states of a select box

    Cette capture d'écran montre les trois états principaux du widget : l'état normal (à gauche), l'état actif (au milieu) et l'état ouvert (à droite).

    En termes de comportement, nous voulons que notre widget soit utilisable aussi bien avec une souris qu'avec un clavier, comme n'importe quel widget natif. Commençons par définir comment le widget atteint chaque état :

    -
    -
    Le widget est dans son état normal :
    -
    +

    Le widget est dans son état normal :

    +
    • la page se charge
    • le widget était actif et l'utilisateur a cliqué quelque part en dehors du widget
    • le widget était actif et l'utilisateur a déplacé le focus sur un autre avec le clavier
    -
    -
    - -

     

    -
    -
    -

    Note : Déplacer le focus dans la page entre les divers widgets se fait généralement en appuyant sur la touche de tabulation, mais ce n'est pas la norme partout. Par exemple, circuler parmi les liens sur une page se fait dans Safari par défaut en utilisant la combinaison Option+Tab.

    +

    Note : Déplacer le focus dans la page entre les divers widgets se fait généralement en appuyant sur la touche de tabulation, mais ce n'est pas la norme partout. Par exemple, circuler parmi les liens sur une page se fait dans Safari par défaut en utilisant la combinaison Option+Tab.

    -
    -
    Le widget est sans son état actif :
    -
    + +

    Le widget est sans son état actif :

    +
    • l'utilisateur clique sur lui
    • l'utilisateur presse la touche Tabulation et obtient le focus
    • le widget était dans l'état ouvert et l'utilisateur a cliqué dessus.
    -
    -
    Le widget est dans un état ouvert :
    -
    + +

    Le widget est dans un état ouvert :

    +
    • le widget est dans un état autre que ouvert et l'utilisateur clique dessus.
    -
    -

    Maintenant que nous savons comment changer les états du widget, il est important de définir comment changer la valeur du widget :

    -
    -
    La valeur change quand :
    -
    +

    La valeur change quand :

    +
    • l'utilisateur clique sur une option quand le widget est dans l'état ouvert
    • l'utilisateur presse la touche ou quand le widget est dans l'état actif
    -
    -

    Enfin, définissons comment les options du widget doivent se comporter :

    @@ -92,7 +80,7 @@ original_slug: >-

    Autre exemple amusant : que se passera-t-il si l'utilisateur presse les touches ou alors que le widget est à l'état ouvert ? Ici, c'est un peu plus délicat. Si vous considérez que l'état actif et l'état ouvert sont totalement différents, la réponse est encore une fois « rien ne se produira » parce que nous n'avons pas défini d'interactions clavier pour l'état ouvert. D'autre part, si vous considérez que l'état actif et l'état ouvert coïncident, la valeur peut changer mais l'option ne sera certainement pas mise en valeur en conséquence, encore une fois parce que nous n'avons pas défini d'interactions clavier sur les options lorsque le widget est dans son état ouvert (nous avons seulement défini ce qui doit se passer lorsque le widget est ouvert, mais rien après).

    -

    Dans notre exemple, les spécifications manquantes sont évidentes et nous les traiterons, mais cela peut devenir un problème réel sur de nouveaux widgets exotiques, pour lesquels personne n'a la moindre idée de ce qu'est le bon comportement. Il est donc toujours bon de passer du temps à l'étape conception, car si vous définissez pauvrement le comportement, ou si vous oubliez de le définir, il sera très difficile de le redéfinir une fois les utilisateurs habitués. Si vous avez des doutes, demandez l'avis des autres, et si vous avez le budget pour cela, n'hésitez pas à faire des tests utilisateur. Ce processus est appelé UX Design (User eXperience). Si vous voulez en savoir plus sur ce sujet, vous devriez consulter les ressources utiles suivantes :

    +

    Dans notre exemple, les spécifications manquantes sont évidentes et nous les traiterons, mais cela peut devenir un problème réel sur de nouveaux widgets exotiques, pour lesquels personne n'a la moindre idée de ce qu'est le bon comportement. Il est donc toujours bon de passer du temps à l'étape conception, car si vous définissez pauvrement le comportement, ou si vous oubliez de le définir, il sera très difficile de le redéfinir une fois les utilisateurs habitués. Si vous avez des doutes, demandez l'avis des autres, et si vous avez le budget pour cela, n'hésitez pas à faire des tests utilisateur. Ce processus est appelé UX Design (User eXperience). Si vous voulez en savoir plus sur ce sujet, vous devriez consulter les ressources utiles suivantes :

    -

    Note : De plus, dans la plupart des systèmes, il y a moyen d'ouvrir l'élément {{HTMLElement("select")}} pour voir tous les choix disponibles (c'est la même chose que de cliquer sur l'élément {{HTMLElement("select")}} avec une souris). Cela se fait avec Alt+ sous Windows et n'a pas été implémenté dans notre exemple - mais il serait facile de le faire, car le mécanisme a déjà été implémenté pour l'événement click.

    +

    Note : De plus, dans la plupart des systèmes, il y a moyen d'ouvrir l'élément {{HTMLElement("select")}} pour voir tous les choix disponibles (c'est la même chose que de cliquer sur l'élément {{HTMLElement("select")}} avec une souris). Cela se fait avec Alt+ sous Windows et n'a pas été implémenté dans notre exemple - mais il serait facile de le faire, car le mécanisme a déjà été implémenté pour l'événement click.

    Definition de la structure HTML et de la sémantique

    @@ -323,7 +311,7 @@ original_slug: >- {{EmbedLiveSample("Open_state",120,130, "", "Web/Guide/HTML/Formulaires/Comment_construire_des_widgets_de_formulaires_personnalisés/Exemple_1")}} - Check out the source code + Check out the source code @@ -333,11 +321,11 @@ original_slug: >-

    Maintenant que le design et la structure sont prêts, nous pouvons écrire le code JAvaScript pour que le widget fonctionne vraiment.

    -

    Avertissement : Le code qui suit a été conçu à des fins éducatives et ne doit pas être utilisé tel quel. Entre autres choses, comme nous le verrons, il n'est pas à l'épreuve du temps et ne fonctionnera pas sur des navigateurs historiques. Il comporte également des parties redondantes. Elles devraient être optimisées pour du code de production.

    +

    Attention : Le code qui suit a été conçu à des fins éducatives et ne doit pas être utilisé tel quel. Entre autres choses, comme nous le verrons, il n'est pas à l'épreuve du temps et ne fonctionnera pas sur des navigateurs historiques. Il comporte également des parties redondantes. Elles devraient être optimisées pour du code de production.

    -

    Note : Créer des widgets réutilisables peut se révéler un peu délicat. L'ébauche de la norme « W3C Web Component » apporte des réponses à cette question particulière. Le projet X-Tag est un essai de mise en œuvre de cette spécification ; nous vous encourageons à y jeter un coup d'œil.

    +

    Note : Créer des widgets réutilisables peut se révéler un peu délicat. L'ébauche de la norme « W3C Web Component » apporte des réponses à cette question particulière. Le projet X-Tag est un essai de mise en œuvre de cette spécification ; nous vous encourageons à y jeter un coup d'œil.

    Pourquoi ne fonctionne-t-il pas ?

    @@ -433,7 +421,7 @@ original_slug: >- {{EmbedLiveSample("JS",120,130, "", "Web/Guide/HTML/Formulaires/Comment_construire_des_widgets_de_formulaires_personnalisés/Exemple_2")}} - Testez le code source + Testez le code source @@ -459,7 +447,7 @@ original_slug: >-
  • {{domxref("element.querySelector","querySelector")}} et {{domxref("element.querySelectorAll","querySelectorAll")}}
  • -

    Au-delà de la disponibilité de ces fonctionnalités spécifiques, il reste encore un problème avant de commencer. L'objet retourné par la fonction {{domxref("element.querySelectorAll","querySelectorAll()")}} est une {{domxref("NodeList")}} plutôt qu'un Array. C'est important, car les objets  Array acceptent la fonction forEach, mais {{domxref("NodeList")}} ne le fait pas. Comme {{domxref("NodeList")}} ressemble vraiment à un Array et que forEach est d'utilisation si commode, nous pouvons facilement ajouter la prise en charge de forEach à {{domxref("NodeList")}} pour nous faciliter la vie, comme ceci :

    +

    Au-delà de la disponibilité de ces fonctionnalités spécifiques, il reste encore un problème avant de commencer. L'objet retourné par la fonction {{domxref("element.querySelectorAll","querySelectorAll()")}} est une {{domxref("NodeList")}} plutôt qu'un Array. C'est important, car les objets  Array acceptent la fonction forEach, mais {{domxref("NodeList")}} ne le fait pas. Comme {{domxref("NodeList")}} ressemble vraiment à un Array et que forEach est d'utilisation si commode, nous pouvons facilement ajouter la prise en charge de forEach à {{domxref("NodeList")}} pour nous faciliter la vie, comme ceci :

    NodeList.prototype.forEach = function (callback) {
       Array.prototype.forEach.call(this, callback);
    @@ -706,7 +694,7 @@ window.addEventListener('load', function () {
       });
     });
    -

    Dans le code ci-dessus, il faut noter l'utilisation de la propriété tabIndex. Utiliser cette propriété est nécessaire pour être sûr que le widget natif n'obtiendra jamais le focus et que le widget personnalisé l'obtiendra quand l'utilisateur utilise le clavier ou la souris.

    +

    Dans le code ci-dessus, il faut noter l'utilisation de la propriété tabIndex. Utiliser cette propriété est nécessaire pour être sûr que le widget natif n'obtiendra jamais le focus et que le widget personnalisé l'obtiendra quand l'utilisateur utilise le clavier ou la souris.

    Et voilà, nous avons terminé ! Voici le résultat :

    @@ -734,11 +722,11 @@ window.addEventListener('load', function () {

    Nous venons de faire quelque chose qui fonctionne, même si nous sommes loin d'avoir une boîte de sélection avec toutes les fonctionnalités, elle fonctionne parfaitement. Mais ce que nous avons fait n'est rien de plus que de jouer avec les DOM. Elle n'a pas de sémantique réelle, et même si elle ressemble à une boîte de sélection, du point de vue du navigateur, ce n'en est pas une, de sorte que les technologies d'assistance ne pourront pas comprendre que c'est une boîte de sélection. Bref, cette jolie nouvelle boîte de sélection n'est pas accessible !

    -

    Heureusement, il existe une solution et elle s'appelle ARIA. ARIA signifie « Accessible Rich Internet Application » et c'est une norme W3C spécialement conçue pour ce que nous faisons ici : rendre accessibles les applications web et les widgets personnalisés. Il s'agit essentiellement d'un ensemble d'attributs qui étendent le HTML afin que nous puissions mieux décrire les rôles, les états et les propriétés comme si l'élément que nous venons de concevoir était l'élément natif pour lequel il essaie de passer. L'utilisation de ces attributs est très simple, alors faisons-le.

    +

    Heureusement, il existe une solution et elle s'appelle ARIA. ARIA signifie « Accessible Rich Internet Application » et c'est une norme W3C spécialement conçue pour ce que nous faisons ici : rendre accessibles les applications web et les widgets personnalisés. Il s'agit essentiellement d'un ensemble d'attributs qui étendent le HTML afin que nous puissions mieux décrire les rôles, les états et les propriétés comme si l'élément que nous venons de concevoir était l'élément natif pour lequel il essaie de passer. L'utilisation de ces attributs est très simple, alors faisons-le.

    L'attribut role

    -

    L'attribut clé utilisé par ARIA est l'attribut role. L'attribut role  accepte une valeur qui définit à quoi sert un élément. Chaque rôle définit ses propres exigences et comportements. Dans notre exemple, nous utiliserons le rôle de listbox. C'est un « rôle composite », ce qui signifie que les éléments ayant ce rôle s'attendent à avoir des enfants, chacun avec un rôle spécifique (dans ce cas, au moins un enfant avec le rôle option).

    +

    L'attribut clé utilisé par ARIA est l'attribut role. L'attribut role  accepte une valeur qui définit à quoi sert un élément. Chaque rôle définit ses propres exigences et comportements. Dans notre exemple, nous utiliserons le rôle de listbox. C'est un « rôle composite », ce qui signifie que les éléments ayant ce rôle s'attendent à avoir des enfants, chacun avec un rôle spécifique (dans ce cas, au moins un enfant avec le rôle option).

    Il faut aussi noter qu'ARIA définit les rôles appliqués par défaut aux balises HTML standard. Par exemple, l'élément {{HTMLElement("table")}} correspond au rôle grid, et l'élément {{HTMLElement("ul")}} correspond au rôle list. Comme nous utilisons un élément {{HTMLElement("ul")}}, nous voulons nous assurer que le rôle listbox de notre widget remplacera le rôle list de l'élément {{HTMLElement("ul")}}. À cette fin, nous utiliserons le rôle presentation. Ce rôle est conçu pour nous permettre d'indiquer qu'un élément n'a pas de signification particulière, et est utilisé uniquement pour présenter de l'information. Nous l'appliquerons à notre élément {{HTMLElement("ul")}}.

    @@ -759,12 +747,12 @@ window.addEventListener('load', function () { </div>
    -

    Note : Inclure à la fois l'attribut role et l'attribut class n'est nécessaire que si vous souhaitez prendre en charge les navigateurs anciens qui n'acceptent pas les selecteurs d'attribut CSS.

    +

    Note : Inclure à la fois l'attribut role et l'attribut class n'est nécessaire que si vous souhaitez prendre en charge les navigateurs anciens qui n'acceptent pas les selecteurs d'attribut CSS.

    L'attribut  aria-selected

    -

    Utiliser l'attribut role ne suffit pas. ARIA fournit également de nombreux états et attributs de propriété. Plus vous les utiliserez, mieux votre widget sera compris par les techniques d'assistance. Dans notre cas, nous limiterons notre utilisation à un seul attribut : aria-selected.

    +

    Utiliser l'attribut role ne suffit pas. ARIA fournit également de nombreux états et attributs de propriété. Plus vous les utiliserez, mieux votre widget sera compris par les techniques d'assistance. Dans notre cas, nous limiterons notre utilisation à un seul attribut : aria-selected.

    L'attribut aria-selected s'utilise pour marquer l'option actuellement sélectionnée ; ceci permet aux techniques d'assistance d'informer l'utilisateur quelle est la sélection en cours. Nous l'utiliserons dynamiquement avec JavaScript pour marquer l'option sélectionnée chaque fois que l'utilisateur en choisit une. Pour cela, nous devons réviser la fonction updateValue() :

    @@ -825,7 +813,7 @@ window.addEventListener('load', function () {
    • Mon premier formulaire HTML
    • -
    • Comment structurer un formulaire HTML
    • +
    • Comment structurer un formulaire HTML
    • Les widgets natifs pour formulaire
    • Envoi des données de formulaire
    • Validation des données de formulaire
    • diff --git a/files/fr/learn/forms/how_to_structure_a_web_form/example/index.html b/files/fr/learn/forms/how_to_structure_a_web_form/example/index.html index cb36b36527..672ae945dd 100644 --- a/files/fr/learn/forms/how_to_structure_a_web_form/example/index.html +++ b/files/fr/learn/forms/how_to_structure_a_web_form/example/index.html @@ -6,7 +6,7 @@ original_slug: Web/Guide/HTML/Formulaires/Comment_structurer_un_formulaire_HTML/ ---

      Ceci est un exemple de formulaire de paiement basique extrait de l'article Comment structurer un formulaire HTML.

      -

      Un formulaire de paiement

      +

      Un formulaire de paiement

      Contenu HTML

      diff --git a/files/fr/learn/forms/how_to_structure_a_web_form/index.html b/files/fr/learn/forms/how_to_structure_a_web_form/index.html index a8f3079705..7f098d890e 100644 --- a/files/fr/learn/forms/how_to_structure_a_web_form/index.html +++ b/files/fr/learn/forms/how_to_structure_a_web_form/index.html @@ -17,13 +17,13 @@ original_slug: Web/Guide/HTML/Formulaires/Comment_structurer_un_formulaire_HTML
      {{PreviousMenuNext("Web/Guide/HTML/Formulaires/Mon_premier_formulaire_HTML", "Web/Guide/HTML/Formulaires/Les_blocs_de_formulaires_natifs", "Web/Guide/HTML/Formulaires")}}
      -

      Les bases vues, nous examinons maintenant plus en détail les éléments utilisés pour structurer et donner un sens aux différentes parties d'un formulaire.

      +

      Les bases vues, nous examinons maintenant plus en détail les éléments utilisés pour structurer et donner un sens aux différentes parties d'un formulaire.

      - +
      - + @@ -40,12 +40,15 @@ original_slug: Web/Guide/HTML/Formulaires/Comment_structurer_un_formulaire_HTML

      Nous l'avons déjà rencontré dans l'article précédent.

      -
      Note : Il est strictement interdit d'imbriquer un formulaire dans un autre formulaire. L'imbrication peut conduire à des comportements imprévisibles selon le navigateur utilisé.
      +
      +

      Note : Il est strictement interdit d'imbriquer un formulaire dans un autre formulaire. L'imbrication peut conduire à des comportements imprévisibles selon le navigateur utilisé. +

      +

      Notez qu'il est toujours possible d'utiliser un widget de formulaire en dehors d'un élément {{HTMLElement("form")}} mais si vous le faites, ce widget de formulaire n'a rien à voir avec un formulaire. De tels widgets peuvent être utilisés en dehors d'un formulaire, mais alors vous devriez avoir un plan spécial pour de tels widgets, puisqu'ils ne feront rien tout seuls. Vous devrez personnaliser leur comportement avec JavaScript.

      -

      Note: HTML5 introduit l'attribut form dans les éléments form du HTML. Il devrait vous permettre de lier explicitement un élément avec un formulaire même s'il n'est pas inclus dans un {{ HTMLElement("form") }}. Malheureusement, pour l'instant, l'implémentation de cette fonctionnalité dans les navigateurs n'est pas encore assez fiable.

      +

      Note : HTML5 introduit l'attribut form dans les éléments form du HTML. Il devrait vous permettre de lier explicitement un élément avec un formulaire même s'il n'est pas inclus dans un {{ HTMLElement("form") }}. Malheureusement, pour l'instant, l'implémentation de cette fonctionnalité dans les navigateurs n'est pas encore assez fiable.

      Les éléments <fieldset> et <legend>

      @@ -56,26 +59,26 @@ original_slug: Web/Guide/HTML/Formulaires/Comment_structurer_un_formulaire_HTML

      Voici un petit exemple :

      -
      <form>
      -  <fieldset>
      -    <legend>Taille du jus de fruits</legend>
      -    <p>
      -      <input type="radio" name="size" id="size_1" value="small">
      -      <label for="size_1">Petite</label>
      -    </p>
      -    <p>
      -      <input type="radio" name="size" id="size_2" value="medium">
      -      <label for="size_2">Moyenne</label>
      -    </p>
      -    <p>
      -      <input type="radio" name="size" id="size_3" value="large">
      -      <label for="size_3">Grande</label>
      -    </p>
      -  </fieldset>
      -</form>
      +
      <form>
      +  <fieldset>
      +    <legend>Taille du jus de fruits</legend>
      +    <p>
      +      <input type="radio" name="size" id="size_1" value="small">
      +      <label for="size_1">Petite</label>
      +    </p>
      +    <p>
      +      <input type="radio" name="size" id="size_2" value="medium">
      +      <label for="size_2">Moyenne</label>
      +    </p>
      +    <p>
      +      <input type="radio" name="size" id="size_3" value="large">
      +      <label for="size_3">Grande</label>
      +    </p>
      +  </fieldset>
      +</form>
      -

      Note : Vous trouverez cet exemple dans fieldset-legend.html (voir directement aussi).

      +

      Note : Vous trouverez cet exemple dans fieldset-legend.html (voir directement aussi).

      En lisant le formulaire ci-dessus, un lecteur d'écran dira « Taille du jus de fruit : petit » pour le premier widget, « Taille du jus de fruit : moyenne » pour le second, et « Taille du jus de fruit : grande » pour le troisième.

      @@ -88,7 +91,7 @@ original_slug: Web/Guide/HTML/Formulaires/Comment_structurer_un_formulaire_HTML

      Comme nous l'avons vu dans l'article précédent, l'élément {{HTMLElement("label")}} est le moyen naturel de définir une étiquette pour un widget de formulaire HTML. C'est l'élément le plus important si vous voulez créer des formulaires accessibles — lorsqu'ils sont correctement implémentés, les lecteurs d'écran énonceront l'étiquette d'un élément de formulaire selon toutes les instructions associées. Prenons cet exemple, que nous avons vu dans l'article précédent :

      -
      <label for="name">Nom :</label> <input type="text" id="name" name="user_name">
      +
      <label for="name">Nom :</label> <input type="text" id="name" name="user_name">

      Avec un élément <label> correctement associé à <input> par l'intermédiaire respectivement des attributs for et id (l'attribut for de <label> référence l'attibut id du widget correspondant), un lecteur d'écran lira et dira quelque chose comme « Nom, texte indiqué ».

      @@ -96,9 +99,9 @@ original_slug: Web/Guide/HTML/Formulaires/Comment_structurer_un_formulaire_HTML

      Notez qu'un widget peut être incorporé dans son élément {{HTMLElement("label")}}, ainsi :

      -
      <label for="name">
      -  Nom : <input type="text" id="name" name="user_name">
      -</label>
      +
      <label for="name">
      +  Nom : <input type="text" id="name" name="user_name">
      +</label>

      Toutefois, même dans ce cas, il est considéré de bonne pratique de définir l'attribut for parce que certaines techniques d'assistance ne font pas implicitement le lien entre les étiquettes et les widgets.

      @@ -108,19 +111,19 @@ original_slug: Web/Guide/HTML/Formulaires/Comment_structurer_un_formulaire_HTML

      Par exemple :

      -
      <form>
      -  <p>
      -    <label for="taste_1">J'aime les cerises</label>
      -    <input type="checkbox" id="taste_1" name="taste_cherry" value="1">
      -  </p>
      -  <p>
      -    <label for="taste_2">J'aime les bananes</label>
      -    <input type="checkbox" id="taste_2" name="taste_banana" value="2">
      -  </p>
      -</form>
      +
      <form>
      +  <p>
      +    <label for="taste_1">J'aime les cerises</label>
      +    <input type="checkbox" id="taste_1" name="taste_cherry" value="1">
      +  </p>
      +  <p>
      +    <label for="taste_2">J'aime les bananes</label>
      +    <input type="checkbox" id="taste_2" name="taste_banana" value="2">
      +  </p>
      +</form>
      -

      Note : Vous trouverez cet exemple dans checkbox-label.html (à voir directement aussi).

      +

      Note : Vous trouverez cet exemple dans checkbox-label.html (à voir directement aussi).

      Étiquettes multiples

      @@ -129,29 +132,29 @@ original_slug: Web/Guide/HTML/Formulaires/Comment_structurer_un_formulaire_HTML

      Considérons cet exemple :

      -
      <p>Les champs obligatoires sont suivis de <abbr title="required">*</abbr>.</p>
      -
      -<!-- Donc ceci : -->
      -<div>
      -  <label for="username">Nom :</label>
      -  <input type="text" name="username">
      -  <label for="username"><abbr title="required">*</abbr></label>
      -</div>
      -
      -<!-- sera mieux programmé ainsi : -->
      -<div>
      -  <label for="username">
      -    <span>Nom :</span>
      -    <input id="username" type="text" name="username">
      -    <abbr title="required">*</abbr>
      -  </label>
      -</div>
      -
      -<!-- mais ceci est probablement encore meilleur : -->
      -<div>
      -  <label for="username">Nom :<abbr title="required">*</abbr></label>
      -  <input id="username" type="text" name="username">
      -</div>
      +
      <p>Les champs obligatoires sont suivis de <abbr title="required">*</abbr>.</p>
      +
      +<!-- Donc ceci : -->
      +<div>
      +  <label for="username">Nom :</label>
      +  <input type="text" name="username">
      +  <label for="username"><abbr title="required">*</abbr></label>
      +</div>
      +
      +<!-- sera mieux programmé ainsi : -->
      +<div>
      +  <label for="username">
      +    <span>Nom :</span>
      +    <input id="username" type="text" name="username">
      +    <abbr title="required">*</abbr>
      +  </label>
      +</div>
      +
      +<!-- mais ceci est probablement encore meilleur : -->
      +<div>
      +  <label for="username">Nom :<abbr title="required">*</abbr></label>
      +  <input id="username" type="text" name="username">
      +</div>

      Le paragraphe du haut définit la règle pour les éléments obligatoires. Ce doit être au début pour s'assurer que les techniques d'assistance telles que les lecteurs d'écran l'afficheront ou le vocaliseront à l'utilisateur avant qu'il ne trouve un élément obligatoire. Ainsi, ils sauront ce que signifie l'astérisque. Un lecteur d'écran mentionnera l'astérisque en disant « astérisque » ou « obligatoire », selon les réglages du lecteur d'écran — dans tous les cas, ce qui sera dit est clairement précisé dans le premier paragraphe.

      @@ -162,11 +165,11 @@ original_slug: Web/Guide/HTML/Formulaires/Comment_structurer_un_formulaire_HTML
      -

      Note : Vous pouvez obtenir des résultats légérement différents, selon votre lecteur d'écran. Ce qui précéde a été testé avec VoiceOver (et NVDA se comporte de la même façon). Nous aimerions avoir un retour sur vos expériences également.

      +

      Note : Vous pouvez obtenir des résultats légérement différents, selon votre lecteur d'écran. Ce qui précéde a été testé avec VoiceOver (et NVDA se comporte de la même façon). Nous aimerions avoir un retour sur vos expériences également.

      -

      Note : Vous trouverez cet exemple sur GitHub dans required-labels.html (à voir directement aussi). Ne lancez pas l'exemple avec 2 ou 3 version non mises en commentaires — le lecteur d'écran serait totalement embrouillé s'il y a plusieurs étiquettes ET plusieurs entrées avec le même ID !

      +

      Note : Vous trouverez cet exemple sur GitHub dans required-labels.html (à voir directement aussi). Ne lancez pas l'exemple avec 2 ou 3 version non mises en commentaires — le lecteur d'écran serait totalement embrouillé s'il y a plusieurs étiquettes ET plusieurs entrées avec le même ID !

      Structures HTML courantes dans les formulaires

      @@ -185,22 +188,22 @@ original_slug: Web/Guide/HTML/Formulaires/Comment_structurer_un_formulaire_HTML

      Mettons ces idées en pratique et construisons une structure de formulaire un peu plus sophistiquée — un formulaire de paiement. Il contiendra un certain nombre de types de widgets que vous ne comprenez pas encore — ne vous inquiétez pas pour l'instant ; vous découvrirez comment ils fonctionnent dans l'article suivant (Les widgets natifs pour formulaire). Pour l'instant, lisez attentivement les descriptions en suivant les instructions ci-dessous et commencez à vous faire une idée des éléments enveloppes que nous utilisons pour structurer le formulaire, et pourquoi.

      -
        +
        1. Pour commencer, faites une copie locale de notre fichier modèle vierge et des CSS pour notre formulaire de paiement dans un nouveau répertoire.
        2. Primo, appliquez les CSS au HTML en ajoutant la ligne suivante dans l'élément {{htmlelement("head")}} du HTML : -
          <link href="payment-form.css" rel="stylesheet">
          +
          <link href="payment-form.css" rel="stylesheet">
        3. Ensuite, commencez le formulaire en ajoutant un élément {{htmlelement("form")}} : -
          <form>
          +  
          <form>
           
           </form>
        4. Entre les balises <form>, ajoutez un en‑tête et un paragraphe pour informer les utilisateurs comment sont marqués les champs obligatoires : -
          <h1>Formulaire de paiement</h1>
          -<p>Les champs obligatoires sont suivis par un <strong><abbr title="required">*</abbr></strong>.</p>
          +
          <h1>Formulaire de paiement</h1>
          +<p>Les champs obligatoires sont suivis par un <strong><abbr title="required">*</abbr></strong>.</p>
        5. Ensuite, nous ajoutons une grande section de code dans le formulaire, sous la précédente. Ici vous verrez que nous enveloppons les champs d'informations de contact dans des éléments {{htmlelement("section")}} distincts. De plus, nous avons un ensemble de deux boutons radio, que nous mettons chacun à l'intérieur de leur propre élément de liste ({{htmlelement("li")}}). Enfin, nous avons deux zones de texte standard {{htmlelement("input")}} et leurs éléments {{htmlelement("label")}} associés, chacun contenu dans un élément {{htmlelement("p")}}, plus une entrée pour le mot de passe. Ajoutez ce code à votre formulaire maintenant : -
          <section>
          +  
          <section>
               <h2>Informations de contact</h2>
               <fieldset>
                 <legend>Qualité</legend>
          @@ -240,10 +243,10 @@ original_slug: Web/Guide/HTML/Formulaires/Comment_structurer_un_formulaire_HTML
                 </label>
                 <input type="password" id="pwd" name="password">
               </p>
          -</section>
          +</section>
        6. Nous arrivons maintenant à la deuxième <section> de notre formulaire — l'information de paiement. Ici nous avons trois widgets distincts avec leur étiquette, chacun contenu dans un paragraphe <p>. Le premier est un menu déroulant ({{htmlelement("select")}}) pour le choix du type de la carte de crédit. Le deuxième  est un élément <input> de type nombre pour entrer le numéro de la carte de crédit. Le dernier est un élément <input> de type date pour entrer la date d'expiration de la carte de crédit (il sera accompagné d'un widget dateur pour les navigateurs prenant en charge cette fonctionnalité, et sera un simple champ textuel pour les navigateurs ne la prenant pas en charge). À nouveau, entrez ce qui suit après la section ci‑dessus : -
          
          +  
           <section>
               <h2>Informations de paiement</h2>
               <p>
          @@ -271,10 +274,10 @@ original_slug: Web/Guide/HTML/Formulaires/Comment_structurer_un_formulaire_HTML
                 </label>
                 <input type="text" id="date" name="expiration">
               </p>
          -</section>
          +</section>
        7. La dernière section est plus simple ; elle ne contient qu'un bouton {{htmlelement("button")}} de type submit, pour adresser les données du formulaire. Ajoutez ceci au bas du formulaire : -
          <p> <button type="submit">Valider le paiement</button> </p>
          +
          <p> <button type="submit">Valider le paiement</button> </p>
        @@ -298,7 +301,7 @@ original_slug: Web/Guide/HTML/Formulaires/Comment_structurer_un_formulaire_HTML
        • Mon premier formulaire HTML
        • -
        • Comment structurer un formulaire HTML
        • +
        • Comment structurer un formulaire HTML
        • Les widgets natifs pour formulaire
        • Envoi des données de formulaire
        • Validation des données de formulaire
        • diff --git a/files/fr/learn/forms/html_forms_in_legacy_browsers/index.html b/files/fr/learn/forms/html_forms_in_legacy_browsers/index.html index 6b9dc84cc2..7f12753fa5 100644 --- a/files/fr/learn/forms/html_forms_in_legacy_browsers/index.html +++ b/files/fr/learn/forms/html_forms_in_legacy_browsers/index.html @@ -6,7 +6,7 @@ original_slug: Web/Guide/HTML/Formulaires/HTML_forms_in_legacy_browsers ---
          {{LearnSidebar}}{{PreviousMenuNext("Web/Guide/HTML/Formulaires/Sending_forms_through_JavaScript", "Web/Guide/HTML/Formulaires/Apparence_des_formulaires_HTML", "Web/Guide/HTML/Formulaires")}}
          -

          Tout développeur apprend très rapidement (parfois difficilement) que le Web est un endroit assez inconfortable. Le pire des fléaux est le « navigateur historique ». Oui, admettons‑le, si on dit « navigateur historique », nous pensons tous aux anciennes versions d'Internet Explorer ... mais elles sont loin d'être les seules. Les premières versions de Firefox, comme la version ESR, sont aussi des « navigateurs historiques ». Et dans le monde du mobile ? Quand ni le navigateur ni l'OS ne peut être mis à jour? Oui, il y a beaucoup de vieux smartphones Android ou des iPhones dont le navigateur par défaut n'est pas à jour. Ceux-ci sont aussi des « navigateurs historiques ».

          +

          Tout développeur apprend très rapidement (parfois difficilement) que le Web est un endroit assez inconfortable. Le pire des fléaux est le « navigateur historique ». Oui, admettons‑le, si on dit « navigateur historique », nous pensons tous aux anciennes versions d'Internet Explorer ... mais elles sont loin d'être les seules. Les premières versions de Firefox, comme la version ESR, sont aussi des « navigateurs historiques ». Et dans le monde du mobile ? Quand ni le navigateur ni l'OS ne peut être mis à jour? Oui, il y a beaucoup de vieux smartphones Android ou des iPhones dont le navigateur par défaut n'est pas à jour. Ceux-ci sont aussi des « navigateurs historiques ».

          Malheureusement, parcourir cette jungle est une facette du métier. Mais opportunément, il existe quelques astuces pour nous aider à résoudre 80 % des problèmes causés par ces vieilles versions de navigateur.

          @@ -67,8 +67,8 @@ original_slug: Web/Guide/HTML/Formulaires/HTML_forms_in_legacy_browsers
      - - + +
      Prérequis :Notions concernant les ordinateurs et les connaissances de base du HTML.Notions concernant les ordinateurs et les connaissances de base du HTML.
      Objectif :
      Capture d'écran de l'entrée de couleur sur Chrome pour Mac OSXCapture d'écran de l'entrée de couleur sur FirefoxCapture d'écran de l'entrée de couleur sur Chrome pour Mac OSXCapture d'écran de l'entrée de couleur sur Firefox
      @@ -189,7 +189,7 @@ input.button {

      L'équipe de Modernizr fait une maintenance opportune de grande liste de « polyfills ». Prenez celui dont vous avez besoin.

      -

      Note : Modernizr a d'autres fonctionnalités remarquables pour faciliter le traitement du JavaScript non obstructif et les tecniques de simplifications élégantes. Prenez connaissance de  la documentation de Modernizr.

      +

      Note : Modernizr a d'autres fonctionnalités remarquables pour faciliter le traitement du JavaScript non obstructif et les tecniques de simplifications élégantes. Prenez connaissance de  la documentation de Modernizr.

      Faites attention aux performances

      @@ -208,7 +208,7 @@ input.button {
      • Mon premier formulaire HTML
      • -
      • Comment structurer un formulaire HTML
      • +
      • Comment structurer un formulaire HTML
      • Les widgets natifs pour formulaire
      • Envoi des données de formulaire
      • Validation des données de formulaire
      • diff --git a/files/fr/learn/forms/index.html b/files/fr/learn/forms/index.html index d4d758bdfc..76832228f3 100644 --- a/files/fr/learn/forms/index.html +++ b/files/fr/learn/forms/index.html @@ -13,9 +13,7 @@ original_slug: Web/Guide/HTML/Formulaires ---

        {{learnSidebar}}

        -
        -

        Ce guide est constitué d'une série d'articles qui vous aideront à maîtriser les formulaires HTML. Les formulaires HTML sont des outils très puissants pour interagir avec l'utilisateur ; toutefois, à cause de raisons historiques et techniques, il n'est pas forcément évident de savoir comment les utiliser de manière optimale. Nous allons aborder tous les aspects des formulaires HTML, de la structure à la décoration, de la gestion des données aux widgets sur-mesure.

        -
        +

        Ce guide est constitué d'une série d'articles qui vous aideront à maîtriser les formulaires HTML. Les formulaires HTML sont des outils très puissants pour interagir avec l'utilisateur ; toutefois, à cause de raisons historiques et techniques, il n'est pas forcément évident de savoir comment les utiliser de manière optimale. Nous allons aborder tous les aspects des formulaires HTML, de la structure à la décoration, de la gestion des données aux widgets sur-mesure.

        Prérequis

        @@ -24,53 +22,53 @@ original_slug: Web/Guide/HTML/Formulaires

        Le reste du module est toutefois un peu plus difficile — il est facile de placer des widgets de formulaire dans une page, mais vous ne pourrez pas en faire vraiment quelque chose sans utiliser quelques fonctionnalités plus avancées, les CSS et le JavaScript. C'est pourquoi, avant de regarder ces autres parties, nous vous recommandons de faire un détour et de procéder d'abord à l'étude des CSS et du JavaScript.

        -

        Note : Si vous travaillez sur un ordinateur/tablette/autre appareil sur lequel vous n'avez pas la possiblité de créer vos propres fichiers, vous pourrez essayer (la plupart) des exemples de code sur un programme de codage en ligne comme JSBin ou Thimble.

        +

        Note : Si vous travaillez sur un ordinateur/tablette/autre appareil sur lequel vous n'avez pas la possiblité de créer vos propres fichiers, vous pourrez essayer (la plupart) des exemples de code sur un programme de codage en ligne comme JSBin ou Thimble.

        -

        Éléments de base

        +

        Éléments de base

        Mon premier formulaire HTML
        Le premier article de notre série vous donne une toute première expérience de création de formulaire en HTML, y compris sa conception, sa mise en œuvre en utilisant les bons éléments HTML, l'ajout de quelques très simples décorations avec les CSS et le comment de l'envoi des données à un serveur.
        -
        Comment structurer un formulaire HTML
        +
        Comment structurer un formulaire HTML
        Les bases vues, nous examinons maintenant plus en détail les éléments utilisés pour structurer et donner un sens aux différentes parties d'un formulaire.

        Quels sont les widgets pour formulaire disponibles ?

        -
        Les widgets natifs pour formulaire
        +
        Les widgets natifs pour formulaire
        Nous examinons maintenant en détail les fonctionnalités des widgets pour formulaire, en regardant quelles sont les options disponibles pour collecter différentes types de données.

        Validation et soumission des données de formulaires

        -
        Envoi des données de formulaire
        +
        Envoi des données de formulaire
        Cet article examine ce qui arrive quand un utilisateur soumet un formulaire — où les données vont-elles et comment les gère-t-on une fois à destination ? Nous examinerons aussi quelques problèmes de sécurité associés à l'envoi des données d'un formulaire.
        -
        Validation des données de formulaire
        +
        Validation des données de formulaire
        Ce n'est pas tout d'envoyer des données — il faut aussi s'assurer que les données mises dans un formulaire par un utilisateur sont de format correct pour pouvoir les traiter correctement et qu'elles ne vont pas casser nos applications. Nous voulons également aider les utilisateurs à compléter les formulaires correctement et à ne pas ressentir de frustration en essayant d'utiliser nos applications. La validation et la soumission des données des formulaires vous aidera à remplir ces objectifs — cet article indique ce qui est nécessaire de savoir.

        Guides avancés

        -
        Comment construire des widgets de formulaires personnalisés
        +
        Comment construire des widgets de formulaires personnalisés
        Nous allons voir quelques cas où les widgets natifs ne donnent pas ce dont vous avez besoin, pour des raisons fonctionnelles ou de style par exemple. Dans de tels cas, vous pouvez avoir besoin de construire vous même un widget de formulaire en dehors du HTML brut. Cet article explique comment faire, ainsi que les considérations à prendre en compte ce faisant, le tout à l'aide de l'étude d'un cas particulier.
        -
        Envoi de formulaires à l'aide du JavaScript
        +
        Envoi de formulaires à l'aide du JavaScript
        Cet article examine les manières d'utiliser un formulaire pour assembler une requête HTTP et l'adresser par l'intermédiaire d'un JavaScript personnalisé, au lieu d'une soumission standard de formulaire. Il examine aussi pourquoi vous pouvez souhaiter faire ainsi et ce que cela implique corrélativement. (Voir aussi « Utilisation des objets FormData ».)
        -
        Formulaires HTML dans les navigateurs anciens
        +
        Formulaires HTML dans les navigateurs anciens
        Cet article couvre les détections de fonctionnalité, etc. Elles doivent être redirigées dans le module de tests croisés entre navigateurs, car la même problématique y sera mieux traitée.

        Guides de mise en forme des formulaires

        -
        Mise en forme des formulaires HTML
        +
        Mise en forme des formulaires HTML
        Cet article est une introduction à la mise en forme des formulaires à l'aide des CSS, y compris tous les éléments de base qu'il est nécessaire de connaître pour les tâches de décoration élémentaires.
        -
        Mise en forme avancée des formulaires HTML
        +
        Mise en forme avancée des formulaires HTML
        Dans cet article, nous regarderons des techniques de mise en forme plus avancées qu'il est nécessaire d'utiliser pour opérer sur les éléments les plus difficiles à traiter.
        -
        Tableau de compatibilité des propriétés entre widgets de formulaire
        +
        Tableau de compatibilité des propriétés entre widgets de formulaire
        Ce dernier article fournit un référentiel pratique vous permettant de rechercher quelles propriétés des CSS sont compatibles avec tel ou tel élément de formulaire.
        diff --git a/files/fr/learn/forms/property_compatibility_table_for_form_controls/index.html b/files/fr/learn/forms/property_compatibility_table_for_form_controls/index.html index 4c702ca4c0..5dea78fc0c 100644 --- a/files/fr/learn/forms/property_compatibility_table_for_form_controls/index.html +++ b/files/fr/learn/forms/property_compatibility_table_for_form_controls/index.html @@ -15,7 +15,7 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ ---
        {{learnsidebar}}{{PreviousMenu("Web/Guide/HTML/Formulaires/Advanced_styling_for_HTML_forms", "Web/Guide/HTML/Formulaires")}}
        -

        Les tables de compatibilité suivantes tentent de résumer l'état de la prise en charge des CSS par les formulaires HTML. Eu égard à la complexité des CSS et des formulaires HTML, ces tables ne peuvent pas être considérées comme un élément de référence parfait. Toutefois, elles vous donneront un bon aperçu de ce qui peut et de ce qui ne peut pas être fait, ce qui vous aidera à apprendre comment faire les choses.

        +

        Les tables de compatibilité suivantes tentent de résumer l'état de la prise en charge des CSS par les formulaires HTML. Eu égard à la complexité des CSS et des formulaires HTML, ces tables ne peuvent pas être considérées comme un élément de référence parfait. Toutefois, elles vous donneront un bon aperçu de ce qui peut et de ce qui ne peut pas être fait, ce qui vous aidera à apprendre comment faire les choses.

        Comment lire les tables

        @@ -92,15 +92,15 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Modèle de boîte CSS - {{cssxref("width")}} - Oui - Oui + {{cssxref("width")}} + Oui + Oui   - {{cssxref("height")}} - Partiel[1][2] - Oui + {{cssxref("height")}} + Partiel + Oui
        1. Les navigateurs WebKit (principalement sur Mac OSX et iOS) utilisent apparence et comportement natifs pour les champs de recherche. Par conséquent, il est nécessaire d'utiliser -webkit-appearance:none pour pouvoir appliquer cette propriété aux champs de recherche.
        2. @@ -109,9 +109,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("border")}} - Partiel[1][2] - Oui + {{cssxref("border")}} + Partiel + Oui
          1. Les navigateurs WebKit (principalement sur Mac OSX et iOS) utilisent apparence et comportement natifs pour les champs de recherche. Par conséquent, il est nécessaire d'utiliser -webkit-appearance:none pour pouvoir appliquer cette propriété aux champs de recherche.
          2. @@ -120,15 +120,15 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("margin")}} - Oui - Oui + {{cssxref("margin")}} + Oui + Oui   - {{cssxref("padding")}} - Partiel[1][2] - Oui + {{cssxref("padding")}} + Partiel + Oui
            1. Les navigateurs WebKit (principalement sur Mac OSX et iOS) utilisent apparence et comportement natifs pour les champs de recherche. Par conséquent, il est nécessaire d'utiliser -webkit-appearance:none pour pouvoir appliquer cette propriété aux champs de recherche.
            2. @@ -142,9 +142,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Texte et polices - {{cssxref("color")}}[1] - Oui - Oui + {{cssxref("color")}} + Oui + Oui
              1. Si la propriété {{cssxref("border-color")}} n'est pas mentionnée, certains navigateurs fondés sur WebKit appliqueront la propriété {{cssxref("color")}} aussi bien à la bordure qu'à la police avec l'élément {{HTMLElement("textarea")}}.
              2. @@ -152,33 +152,33 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("font")}} - Oui - Oui + {{cssxref("font")}} + Oui + Oui Voir la note à propos de {{cssxref("line-height")}} - {{cssxref("letter-spacing")}} - Oui - Oui + {{cssxref("letter-spacing")}} + Oui + Oui   - {{cssxref("text-align")}} - Oui - Oui + {{cssxref("text-align")}} + Oui + Oui   - {{cssxref("text-decoration")}} - Partiel - Partiel + {{cssxref("text-decoration")}} + Partiel + Partiel Voir la note à propos de Opera - {{cssxref("text-indent")}} - Partiel[1] - Partiel[1] + {{cssxref("text-indent")}} + Partiel + Partiel
                1. IE9 prend en charge cette propriété uniquement sur les éléments {{HTMLElement("textarea")}}, alors que Opera ne la prend en charge que sur les champs texte sur une ligne.
                2. @@ -186,21 +186,21 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("text-overflow")}} - Partiel - Partiel + {{cssxref("text-overflow")}} + Partiel + Partiel   - {{cssxref("text-shadow")}} - Partiel - Partiel + {{cssxref("text-shadow")}} + Partiel + Partiel   - {{cssxref("text-transform")}} - Oui - Oui + {{cssxref("text-transform")}} + Oui + Oui   @@ -209,9 +209,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Bordure et arrière-plan - {{cssxref("background")}} - Partiel[1] - Oui + {{cssxref("background")}} + Partiel + Oui
                  1. Les navigateurs WebKit (principalement sur Mac OSX et iOS) utilisent apparence et comportement natifs pour les champs de recherche. Par conséquent, il est nécessaire d'utiliser -webkit-appearance:none pour pouvoir appliquer cette propriété aux champs de recherche. Sous Windows 7, Internet Explorer 9 n'applique pas la bordure à moins que background:none ne soit utilisé.
                  2. @@ -219,9 +219,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("border-radius")}} - Partiel[1][2] - Oui + {{cssxref("border-radius")}} + Partiel + Oui
                    1. Les navigateurs WebKit (principalement sur Mac OSX et iOS) utilisent apparence et comportement natifs pour les champs de recherche. Par conséquent, il est nécessaire d'utiliser -webkit-appearance:none pour pouvoir appliquer cette propriété aux champs de recherche. Sous Windows 7, Internet Explorer 9 n'applique pas la bordure à moins que background:none ne soit utilisé.
                    2. @@ -230,9 +230,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("box-shadow")}} - Non - Partiel[1] + {{cssxref("box-shadow")}} + Non + Partiel
                      1. IE9 ne prend pas en charge cette propriété.
                      2. @@ -258,15 +258,15 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Modèle de boîte CSS - {{cssxref("width")}} - Oui - Oui + {{cssxref("width")}} + Oui + Oui   - {{cssxref("height")}} - Partiel[1] - Oui + {{cssxref("height")}} + Partiel + Oui
                        1. Cette propriété n'est pas appliquée sur les navigateurs fondés sur WebKit sur Mac OSX ou iOS.
                        2. @@ -274,21 +274,21 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("border")}} - Partiel - Oui + {{cssxref("border")}} + Partiel + Oui   - {{cssxref("margin")}} - Oui - Oui + {{cssxref("margin")}} + Oui + Oui   - {{cssxref("padding")}} - Partiel[1] - Oui + {{cssxref("padding")}} + Partiel + Oui
                          1. Cette propriété n'est pas appliquée sur les navigateurs fondés sur WebKit sur Mac OSX ou iOS.
                          2. @@ -301,57 +301,57 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Texte et polices - {{cssxref("color")}} - Oui - Oui + {{cssxref("color")}} + Oui + Oui   - {{cssxref("font")}} - Oui - Oui + {{cssxref("font")}} + Oui + Oui Voir la note à propos de {{cssxref("line-height")}}. - {{cssxref("letter-spacing")}} - Oui - Oui + {{cssxref("letter-spacing")}} + Oui + Oui   - {{cssxref("text-align")}} - Non - Non + {{cssxref("text-align")}} + Non + Non   - {{cssxref("text-decoration")}} - Partiel - Oui + {{cssxref("text-decoration")}} + Partiel + Oui   - {{cssxref("text-indent")}} - Oui - Oui + {{cssxref("text-indent")}} + Oui + Oui   - {{cssxref("text-overflow")}} - Non - Non + {{cssxref("text-overflow")}} + Non + Non   - {{cssxref("text-shadow")}} - Partiel - Partiel + {{cssxref("text-shadow")}} + Partiel + Partiel   - {{cssxref("text-transform")}} - Oui - Oui + {{cssxref("text-transform")}} + Oui + Oui   @@ -360,15 +360,15 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Bordure et arrière-plan - {{cssxref("background")}} - Oui - Oui + {{cssxref("background")}} + Oui + Oui   - {{cssxref("border-radius")}} - Yes[1] - Yes[1] + {{cssxref("border-radius")}} + Yes + Yes
                            1. Sur Opera la propriété {{cssxref("border-radius")}} n'est appliquée que si une bordure est explicitement définie.
                            2. @@ -376,9 +376,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("box-shadow")}} - Non - Partiel[1] + {{cssxref("box-shadow")}} + Non + Partiel
                              1. IE9 ne prend pas en charge cette propriété.
                              2. @@ -406,15 +406,15 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Modèle de boîte CSS - {{cssxref("width")}} - Oui - Oui + {{cssxref("width")}} + Oui + Oui   - {{cssxref("height")}} - Partiel[1] - Partiel[1] + {{cssxref("height")}} + Partiel + Partiel
                                1. Sur Opera, les roulettes sont zoomés, ce qui peut masquer le contenu du champ.
                                2. @@ -422,21 +422,21 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("border")}} - Oui - Oui + {{cssxref("border")}} + Oui + Oui   - {{cssxref("margin")}} - Oui - Oui + {{cssxref("margin")}} + Oui + Oui   - {{cssxref("padding")}} - Partiel[1] - Partiel[1] + {{cssxref("padding")}} + Partiel + Partiel
                                  1. Sur Opera, les roulettes sont zoomés, ce qui peut masquer le contenu du champ.
                                  2. @@ -449,55 +449,55 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Texte et polices - {{cssxref("color")}} - Oui - Oui + {{cssxref("color")}} + Oui + Oui   - {{cssxref("font")}} - Oui - Oui + {{cssxref("font")}} + Oui + Oui Voir la note à propos de {{cssxref("line-height")}}. - {{cssxref("letter-spacing")}} - Oui - Oui + {{cssxref("letter-spacing")}} + Oui + Oui   - {{cssxref("text-align")}} - Oui - Oui + {{cssxref("text-align")}} + Oui + Oui   - {{cssxref("text-decoration")}} - Partiel - Partiel + {{cssxref("text-decoration")}} + Partiel + Partiel   - {{cssxref("text-indent")}} - Oui - Oui + {{cssxref("text-indent")}} + Oui + Oui   - {{cssxref("text-overflow")}} - Non - Non + {{cssxref("text-overflow")}} + Non + Non   - {{cssxref("text-shadow")}} - Partiel - Partiel + {{cssxref("text-shadow")}} + Partiel + Partiel   - {{cssxref("text-transform")}} + {{cssxref("text-transform")}} N.A. N.A.   @@ -508,22 +508,22 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Bordure et arrière‑plan - {{cssxref("background")}} - Non - Non + {{cssxref("background")}} + Non + Non

                                    Pris en charge mais il y a trop d'incohérence entre les navigateurs pour que ce soit fiable.

                                    - {{cssxref("border-radius")}} - Non - Non + {{cssxref("border-radius")}} + Non + Non - {{cssxref("box-shadow")}} - Non - Non + {{cssxref("box-shadow")}} + Non + Non @@ -544,9 +544,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Modèle de boîte CSS - {{cssxref("width")}} - Non[1] - Non[1] + {{cssxref("width")}} + Non + Non
                                    1. Certains navigateurs ajoutent des marges supplémentaires et d'autres étirent le widget.
                                    2. @@ -554,9 +554,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("height")}} - Non[1] - Non[1] + {{cssxref("height")}} + Non + Non
                                      1. Certains navigateurs ajoutent des marges supplémentaires et d'autres étirent le widget.
                                      2. @@ -564,21 +564,21 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("border")}} - Non - Non + {{cssxref("border")}} + Non + Non   - {{cssxref("margin")}} - Oui - Oui + {{cssxref("margin")}} + Oui + Oui   - {{cssxref("padding")}} - Non - Non + {{cssxref("padding")}} + Non + Non   @@ -587,55 +587,55 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Texte et polices - {{cssxref("color")}} + {{cssxref("color")}} N.A. N.A.   - {{cssxref("font")}} + {{cssxref("font")}} N.A. N.A.   - {{cssxref("letter-spacing")}} + {{cssxref("letter-spacing")}} N.A. N.A.   - {{cssxref("text-align")}} + {{cssxref("text-align")}} N.A. N.A.   - {{cssxref("text-decoration")}} + {{cssxref("text-decoration")}} N.A. N.A.   - {{cssxref("text-indent")}} + {{cssxref("text-indent")}} N.A. N.A.   - {{cssxref("text-overflow")}} + {{cssxref("text-overflow")}} N.A. N.A.   - {{cssxref("text-shadow")}} + {{cssxref("text-shadow")}} N.A. N.A.   - {{cssxref("text-transform")}} + {{cssxref("text-transform")}} N.A. N.A.   @@ -646,21 +646,21 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Bordure et arrière-plan - {{cssxref("background")}} - Non - Non + {{cssxref("background")}} + Non + Non   - {{cssxref("border-radius")}} - Non - Non + {{cssxref("border-radius")}} + Non + Non   - {{cssxref("box-shadow")}} - Non - Non + {{cssxref("box-shadow")}} + Non + Non   @@ -684,9 +684,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Modèle de boîte CSS - {{cssxref("width")}} - Partiel[1] - Partiel[1] + {{cssxref("width")}} + Partiel + Partiel
                                        1. Cette propriété est correcte sur l'élément {{HTMLElement("select")}}, mais cela peut ne pas être le cas sur les éléments {{HTMLElement("option")}} ou {{HTMLElement("optgroup")}}.
                                        2. @@ -694,27 +694,27 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("height")}} - Non - Oui + {{cssxref("height")}} + Non + Oui   - {{cssxref("border")}} - Partiel - Oui + {{cssxref("border")}} + Partiel + Oui   - {{cssxref("margin")}} - Oui - Oui + {{cssxref("margin")}} + Oui + Oui   - {{cssxref("padding")}} - Non[1] - Partiel[2] + {{cssxref("padding")}} + Non + Partiel
                                          1. La propriété est appliquée, mais de manière incohérente entre navigateurs sous Mac OSX.
                                          2. @@ -728,9 +728,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Texte et polices - {{cssxref("color")}} - Partiel[1] - Partiel[1] + {{cssxref("color")}} + Partiel + Partiel
                                            1. Sur Mac OSX, les navigateurs fondés sur WebKit ne prennent pas en charge cette propriété sur les widgets natifs et, avec Opera, ils ne la prennent pas du tout en charge sur les éléments {{HTMLElement("option")}} et {{HTMLElement("optgroup")}}.
                                            2. @@ -738,9 +738,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("font")}} - Partiel[1] - Partiel[1] + {{cssxref("font")}} + Partiel + Partiel
                                              1. Sur Mac OSX, les navigateurs fondés sur WebKit ne prennent pas en charge cette propriété sur les widgets natifs et, avec Opera, ils ne la prennent pas du tout en charge sur les éléments {{HTMLElement("option")}} et {{HTMLElement("optgroup")}}.
                                              2. @@ -748,9 +748,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("letter-spacing")}} - Partiel[1] - Partiel[1] + {{cssxref("letter-spacing")}} + Partiel + Partiel
                                                1. IE9 ne prend pas en charge cette propriété sur les éléments {{HTMLElement("select")}}, {{HTMLElement("option")}}, et {{HTMLElement("optgroup")}} ; les navigateurs fondés sur WebKit sur Mac OSX ne prennent pas en charge cette propriété sur les éléments {{HTMLElement("option")}} et {{HTMLElement("optgroup")}}.
                                                2. @@ -758,9 +758,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("text-align")}} - No[1] - No[1] + {{cssxref("text-align")}} + No + No
                                                  1. IE9 sous Windows 7 et les navigateurs fondés sur WebKit sous Mac OSX ne prennent pas en charge cette propriété pour ce widget.
                                                  2. @@ -768,9 +768,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("text-decoration")}} - Partiel[1] - Partiel[1] + {{cssxref("text-decoration")}} + Partiel + Partiel
                                                    1. Seul Firefox fournit une prise en charge totale de cette propriété. Opera ne la prend pas du tout en charge et d'autres navigateur ne le font que pour l'élément  {{HTMLElement("select")}}.
                                                    2. @@ -778,9 +778,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("text-indent")}} - Partiel[1][2] - Partiel[1][2] + {{cssxref("text-indent")}} + Partiel + Partiel
                                                      1. La plupart des navigateurs ne prennent en charge cette propriété que pour l'élément {{HTMLElement("select")}}.
                                                      2. @@ -789,15 +789,15 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("text-overflow")}} - Non - Non + {{cssxref("text-overflow")}} + Non + Non   - {{cssxref("text-shadow")}} - Partiel[1][2] - Partiel[1][2] + {{cssxref("text-shadow")}} + Partiel + Partiel
                                                        1. La plupart des navigateurs ne prennent en charge cette propriété que pour l'élément {{HTMLElement("select")}}.
                                                        2. @@ -806,9 +806,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("text-transform")}} - Partiel[1] - Partiel[1] + {{cssxref("text-transform")}} + Partiel + Partiel
                                                          1. La plupart des navigateurs ne prennent en charge cette propriété que pour l'élément {{HTMLElement("select")}}.
                                                          2. @@ -821,9 +821,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Bordure et arrière-plan - {{cssxref("background")}} - Partiel[1] - Partiel[1] + {{cssxref("background")}} + Partiel + Partiel
                                                            1. La plupart des navigateurs ne prennent en charge cette propriété que pour l'élément {{HTMLElement("select")}}.
                                                            2. @@ -831,14 +831,14 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("border-radius")}} - Partiel[1] - Partiel[1] + {{cssxref("border-radius")}} + Partiel + Partiel - {{cssxref("box-shadow")}} - Non - Partiel[1] + {{cssxref("box-shadow")}} + Non + Partiel @@ -859,33 +859,33 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Modèle de boîte CSS - {{cssxref("width")}} - Oui - Oui + {{cssxref("width")}} + Oui + Oui   - {{cssxref("height")}} - Oui - Oui + {{cssxref("height")}} + Oui + Oui   - {{cssxref("border")}} - Oui - Oui + {{cssxref("border")}} + Oui + Oui   - {{cssxref("margin")}} - Oui - Oui + {{cssxref("margin")}} + Oui + Oui   - {{cssxref("padding")}} - Partiel[1] - Partiel[1] + {{cssxref("padding")}} + Partiel + Partiel
                                                              1. Opera ne prend pas en charge {{cssxref("padding-top")}} et {{cssxref("padding-bottom")}} sur l'élément {{HTMLElement("select")}}.
                                                              2. @@ -898,21 +898,21 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Texte et polices - {{cssxref("color")}} - Oui - Oui + {{cssxref("color")}} + Oui + Oui   - {{cssxref("font")}} - Oui - Oui + {{cssxref("font")}} + Oui + Oui Voir la note à propos de {{cssxref("line-height")}}. - {{cssxref("letter-spacing")}} - Partiel[1] - Partiel[1] + {{cssxref("letter-spacing")}} + Partiel + Partiel
                                                                1. IE9 ne prend pas en charge cette propriété sur les éléments {{HTMLElement("select")}}, {{HTMLElement("option")}}, et {{HTMLElement("optgroup")}} ; les navigateurs fondés sur WebKit sur Mac OSX ne prennent pas en charge cette propriété sur les éléments {{HTMLElement("option")}} et {{HTMLElement("optgroup")}}.
                                                                2. @@ -920,9 +920,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("text-align")}} - No[1] - No[1] + {{cssxref("text-align")}} + No + No
                                                                  1. IE9 sous Windows 7 et les navigateurs fondés sur WebKit sous Mac OSX ne prennent pas en charge cette propriété sur ce widget.
                                                                  2. @@ -930,9 +930,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("text-decoration")}} - No[1] - No[1] + {{cssxref("text-decoration")}} + No + No
                                                                    1. Uniquement pris en charge par Firefox et IE9+.
                                                                    2. @@ -940,27 +940,27 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("text-indent")}} - Non - Non + {{cssxref("text-indent")}} + Non + Non   - {{cssxref("text-overflow")}} - Non - Non + {{cssxref("text-overflow")}} + Non + Non   - {{cssxref("text-shadow")}} - Non - Non + {{cssxref("text-shadow")}} + Non + Non   - {{cssxref("text-transform")}} - Partiel[1] - Partiel[1] + {{cssxref("text-transform")}} + Partiel + Partiel
                                                                      1. La plupart des navigateurs ne prennent en charge cette propriété que pour l'élément {{HTMLElement("select")}}.
                                                                      2. @@ -973,15 +973,15 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Bordure et arrière-plan - {{cssxref("background")}} - Oui - Oui + {{cssxref("background")}} + Oui + Oui   - {{cssxref("border-radius")}} - Yes[1] - Yes[1] + {{cssxref("border-radius")}} + Yes + Yes
                                                                        1. Sur Opera la propriété {{cssxref("border-radius")}} n'est appliquée que si une bordure est explicitement définie.
                                                                        2. @@ -989,9 +989,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("box-shadow")}} - Non - Partiel[1] + {{cssxref("box-shadow")}} + Non + Partiel
                                                                          1. IE9 ne prend pas en charge cette propriété.
                                                                          2. @@ -1017,33 +1017,33 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Modèle de boîte CSS - {{cssxref("width")}} - Non - Non + {{cssxref("width")}} + Non + Non   - {{cssxref("height")}} - Non - Non + {{cssxref("height")}} + Non + Non   - {{cssxref("border")}} - Non - Non + {{cssxref("border")}} + Non + Non   - {{cssxref("margin")}} - Non - Non + {{cssxref("margin")}} + Non + Non   - {{cssxref("padding")}} - Non - Non + {{cssxref("padding")}} + Non + Non   @@ -1052,57 +1052,57 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Texte et polices - {{cssxref("color")}} - Non - Non + {{cssxref("color")}} + Non + Non   - {{cssxref("font")}} - Non - Non + {{cssxref("font")}} + Non + Non   - {{cssxref("letter-spacing")}} - Non - Non + {{cssxref("letter-spacing")}} + Non + Non   - {{cssxref("text-align")}} - Non - Non + {{cssxref("text-align")}} + Non + Non   - {{cssxref("text-decoration")}} - Non - Non + {{cssxref("text-decoration")}} + Non + Non   - {{cssxref("text-indent")}} - Non - Non + {{cssxref("text-indent")}} + Non + Non   - {{cssxref("text-overflow")}} - Non - Non + {{cssxref("text-overflow")}} + Non + Non   - {{cssxref("text-shadow")}} - Non - Non + {{cssxref("text-shadow")}} + Non + Non   - {{cssxref("text-transform")}} - Non - Non + {{cssxref("text-transform")}} + Non + Non   @@ -1111,21 +1111,21 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Bordure et arrière-plan - {{cssxref("background")}} - Non - Non + {{cssxref("background")}} + Non + Non   - {{cssxref("border-radius")}} - Non - Non + {{cssxref("border-radius")}} + Non + Non   - {{cssxref("box-shadow")}} - Non - Non + {{cssxref("box-shadow")}} + Non + Non   @@ -1147,33 +1147,33 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Modèle de boîte CSS - {{cssxref("width")}} - Non - Non + {{cssxref("width")}} + Non + Non   - {{cssxref("height")}} - Non - Non + {{cssxref("height")}} + Non + Non   - {{cssxref("border")}} - Non - Non + {{cssxref("border")}} + Non + Non   - {{cssxref("margin")}} - Oui - Oui + {{cssxref("margin")}} + Oui + Oui   - {{cssxref("padding")}} - Non - Non + {{cssxref("padding")}} + Non + Non   @@ -1182,15 +1182,15 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Texte et polices - {{cssxref("color")}} - Oui - Oui + {{cssxref("color")}} + Oui + Oui   - {{cssxref("font")}} - No[1] - No[1] + {{cssxref("font")}} + No + No
                                                                            1. Pris en charge mais il y a trop d'incohérence entre les navigateurs pour que ce soit fiable.
                                                                            2. @@ -1198,9 +1198,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("letter-spacing")}} - Partiel[1] - Partiel[1] + {{cssxref("letter-spacing")}} + Partiel + Partiel
                                                                              1. Beaucoup de navigateurs appliquent cette propriété sur le bouton de sélection.
                                                                              2. @@ -1208,21 +1208,21 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("text-align")}} - Non - Non + {{cssxref("text-align")}} + Non + Non   - {{cssxref("text-decoration")}} - Non - Non + {{cssxref("text-decoration")}} + Non + Non   - {{cssxref("text-indent")}} - Partiel[1] - Partiel[1] + {{cssxref("text-indent")}} + Partiel + Partiel
                                                                                1. Agit plus ou moins comme une marge supplementaire en dehors du widget.
                                                                                2. @@ -1230,21 +1230,21 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("text-overflow")}} - Non - Non + {{cssxref("text-overflow")}} + Non + Non   - {{cssxref("text-shadow")}} - Non - Non + {{cssxref("text-shadow")}} + Non + Non   - {{cssxref("text-transform")}} - Non - Non + {{cssxref("text-transform")}} + Non + Non   @@ -1253,9 +1253,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Bordure et arrière-plan - {{cssxref("background")}} - No[1] - No[1] + {{cssxref("background")}} + No + No
                                                                                  1. Pris en charge mais il y a trop d'incohérence entre les navigateurs pour que ce soit fiable.
                                                                                  2. @@ -1263,15 +1263,15 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("border-radius")}} - Non - Non + {{cssxref("border-radius")}} + Non + Non   - {{cssxref("box-shadow")}} - Non - Partiel[1] + {{cssxref("box-shadow")}} + Non + Partiel
                                                                                    1. IE9 ne prend pas en charge cette propriété.
                                                                                    2. @@ -1299,33 +1299,33 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Modèle de boîte CSS - {{cssxref("width")}} - Non - Non + {{cssxref("width")}} + Non + Non   - {{cssxref("height")}} - Non - Non + {{cssxref("height")}} + Non + Non   - {{cssxref("border")}} - Non - Non + {{cssxref("border")}} + Non + Non   - {{cssxref("margin")}} - Oui - Oui + {{cssxref("margin")}} + Oui + Oui   - {{cssxref("padding")}} - Non - Non + {{cssxref("padding")}} + Non + Non   @@ -1334,57 +1334,57 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Texte et polices - {{cssxref("color")}} - Non - Non + {{cssxref("color")}} + Non + Non   - {{cssxref("font")}} - Non - Non + {{cssxref("font")}} + Non + Non   - {{cssxref("letter-spacing")}} - Non - Non + {{cssxref("letter-spacing")}} + Non + Non   - {{cssxref("text-align")}} - Non - Non + {{cssxref("text-align")}} + Non + Non   - {{cssxref("text-decoration")}} - Non - Non + {{cssxref("text-decoration")}} + Non + Non   - {{cssxref("text-indent")}} - Non - Non + {{cssxref("text-indent")}} + Non + Non   - {{cssxref("text-overflow")}} - Non - Non + {{cssxref("text-overflow")}} + Non + Non   - {{cssxref("text-shadow")}} - Non - Non + {{cssxref("text-shadow")}} + Non + Non   - {{cssxref("text-transform")}} - Non - Non + {{cssxref("text-transform")}} + Non + Non   @@ -1393,21 +1393,21 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Bordure et arrière-plan - {{cssxref("background")}} - Non - Non + {{cssxref("background")}} + Non + Non   - {{cssxref("border-radius")}} - Non - Non + {{cssxref("border-radius")}} + Non + Non   - {{cssxref("box-shadow")}} - Non - Non + {{cssxref("box-shadow")}} + Non + Non   @@ -1431,15 +1431,15 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Modèle de boîte CSS - {{cssxref("width")}} - Oui - Oui + {{cssxref("width")}} + Oui + Oui   - {{cssxref("height")}} - No[1] - Oui + {{cssxref("height")}} + No + Oui
                                                                                      1. Opera gère cette propriété comme pour un widget select avec les mêmes restrictions.
                                                                                      2. @@ -1447,21 +1447,21 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("border")}} - Oui - Oui + {{cssxref("border")}} + Oui + Oui   - {{cssxref("margin")}} - Oui - Oui + {{cssxref("margin")}} + Oui + Oui   - {{cssxref("padding")}} - No[1] - Oui + {{cssxref("padding")}} + No + Oui
                                                                                        1. Opera gère cette propriété comme pour un widget select avec les mêmes restrictions.
                                                                                        2. @@ -1474,55 +1474,55 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Texte et polices - {{cssxref("color")}} + {{cssxref("color")}} N.A. N.A.   - {{cssxref("font")}} + {{cssxref("font")}} N.A. N.A.   - {{cssxref("letter-spacing")}} + {{cssxref("letter-spacing")}} N.A. N.A.   - {{cssxref("text-align")}} + {{cssxref("text-align")}} N.A. N.A.   - {{cssxref("text-decoration")}} + {{cssxref("text-decoration")}} N.A. N.A.   - {{cssxref("text-indent")}} + {{cssxref("text-indent")}} N.A. N.A.   - {{cssxref("text-overflow")}} + {{cssxref("text-overflow")}} N.A. N.A.   - {{cssxref("text-shadow")}} + {{cssxref("text-shadow")}} N.A. N.A.   - {{cssxref("text-transform")}} + {{cssxref("text-transform")}} N.A. N.A.   @@ -1533,9 +1533,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Bordure et arrière-plan - {{cssxref("background")}} - No[1] - No[1] + {{cssxref("background")}} + No + No
                                                                                          1. Pris en charge mais il y a trop d'incohérence entre les navigateurs pour que ce soit fiable.
                                                                                          2. @@ -1543,14 +1543,14 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("border-radius")}} - No[1] - No[1] + {{cssxref("border-radius")}} + No + No - {{cssxref("box-shadow")}} - No[1] - No[1] + {{cssxref("box-shadow")}} + No + No @@ -1573,33 +1573,33 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Modèle de boîte CSS - {{cssxref("width")}} - Oui - Oui + {{cssxref("width")}} + Oui + Oui   - {{cssxref("height")}} - Oui - Oui + {{cssxref("height")}} + Oui + Oui   - {{cssxref("border")}} - Partiel - Oui + {{cssxref("border")}} + Partiel + Oui   - {{cssxref("margin")}} - Oui - Oui + {{cssxref("margin")}} + Oui + Oui   - {{cssxref("padding")}} - Oui - Partiel[1] + {{cssxref("padding")}} + Oui + Partiel
                                                                                            1. Chrome cache les éléments {{HTMLElement("progress")}} et {{HTMLElement("meter")}} quand la propriété {{cssxref("padding")}} est appliquée sur un élément altéré.
                                                                                            2. @@ -1612,55 +1612,55 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Texte et polices - {{cssxref("color")}} + {{cssxref("color")}} N.A. N.A.   - {{cssxref("font")}} + {{cssxref("font")}} N.A. N.A.   - {{cssxref("letter-spacing")}} + {{cssxref("letter-spacing")}} N.A. N.A.   - {{cssxref("text-align")}} + {{cssxref("text-align")}} N.A. N.A.   - {{cssxref("text-decoration")}} + {{cssxref("text-decoration")}} N.A. N.A.   - {{cssxref("text-indent")}} + {{cssxref("text-indent")}} N.A. N.A.   - {{cssxref("text-overflow")}} + {{cssxref("text-overflow")}} N.A. N.A.   - {{cssxref("text-shadow")}} + {{cssxref("text-shadow")}} N.A. N.A.   - {{cssxref("text-transform")}} + {{cssxref("text-transform")}} N.A. N.A.   @@ -1671,9 +1671,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Bordure et arrière-plan - {{cssxref("background")}} - No[1] - No[1] + {{cssxref("background")}} + No + No
                                                                                              1. Pris en charge mais il y a trop d'incohérence entre les navigateurs pour que ce soit fiable.
                                                                                              2. @@ -1681,14 +1681,14 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("border-radius")}} - No[1] - No[1] + {{cssxref("border-radius")}} + No + No - {{cssxref("box-shadow")}} - No[1] - No[1] + {{cssxref("box-shadow")}} + No + No @@ -1711,15 +1711,15 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Modèle de boîte CSS - {{cssxref("width")}} - Oui - Oui + {{cssxref("width")}} + Oui + Oui   - {{cssxref("height")}} - Partiel[1] - Partiel[1] + {{cssxref("height")}} + Partiel + Partiel
                                                                                                1. Chrome et Opera ajoutent quelque espace supplémentaire autour du widget, alors que Opera sous Windows 7 réduit la poignée de range.
                                                                                                2. @@ -1727,21 +1727,21 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("border")}} - Non - Oui + {{cssxref("border")}} + Non + Oui   - {{cssxref("margin")}} - Oui - Oui + {{cssxref("margin")}} + Oui + Oui   - {{cssxref("padding")}} - Partiel[1] - Oui + {{cssxref("padding")}} + Partiel + Oui
                                                                                                  1. La propriété {{cssxref("padding")}} est appliquée, mais elle n'a aucun effet visible.
                                                                                                  2. @@ -1754,55 +1754,55 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Texte et polices - {{cssxref("color")}} + {{cssxref("color")}} N.A. N.A.   - {{cssxref("font")}} + {{cssxref("font")}} N.A. N.A.   - {{cssxref("letter-spacing")}} + {{cssxref("letter-spacing")}} N.A. N.A.   - {{cssxref("text-align")}} + {{cssxref("text-align")}} N.A. N.A.   - {{cssxref("text-decoration")}} + {{cssxref("text-decoration")}} N.A. N.A.   - {{cssxref("text-indent")}} + {{cssxref("text-indent")}} N.A. N.A.   - {{cssxref("text-overflow")}} + {{cssxref("text-overflow")}} N.A. N.A.   - {{cssxref("text-shadow")}} + {{cssxref("text-shadow")}} N.A. N.A.   - {{cssxref("text-transform")}} + {{cssxref("text-transform")}} N.A. N.A.   @@ -1813,9 +1813,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Bordure et arrière-plan - {{cssxref("background")}} - No[1] - No[1] + {{cssxref("background")}} + No + No
                                                                                                    1. Pris en charge mais il y a trop d'incohérence entre les navigateurs pour que ce soit fiable.
                                                                                                    2. @@ -1823,14 +1823,14 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("border-radius")}} - No[1] - No[1] + {{cssxref("border-radius")}} + No + No - {{cssxref("box-shadow")}} - No[1] - No[1] + {{cssxref("box-shadow")}} + No + No @@ -1851,33 +1851,33 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Modèle de boîte CSS - {{cssxref("width")}} - Oui - Oui + {{cssxref("width")}} + Oui + Oui   - {{cssxref("height")}} - Oui - Oui + {{cssxref("height")}} + Oui + Oui   - {{cssxref("border")}} - Oui - Oui + {{cssxref("border")}} + Oui + Oui   - {{cssxref("margin")}} - Oui - Oui + {{cssxref("margin")}} + Oui + Oui   - {{cssxref("padding")}} - Oui - Oui + {{cssxref("padding")}} + Oui + Oui   @@ -1886,55 +1886,55 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Texte et polices - {{cssxref("color")}} + {{cssxref("color")}} N.A. N.A.   - {{cssxref("font")}} + {{cssxref("font")}} N.A. N.A.   - {{cssxref("letter-spacing")}} + {{cssxref("letter-spacing")}} N.A. N.A.   - {{cssxref("text-align")}} + {{cssxref("text-align")}} N.A. N.A.   - {{cssxref("text-decoration")}} + {{cssxref("text-decoration")}} N.A. N.A.   - {{cssxref("text-indent")}} + {{cssxref("text-indent")}} N.A. N.A.   - {{cssxref("text-overflow")}} + {{cssxref("text-overflow")}} N.A. N.A.   - {{cssxref("text-shadow")}} + {{cssxref("text-shadow")}} N.A. N.A.   - {{cssxref("text-transform")}} + {{cssxref("text-transform")}} N.A. N.A.   @@ -1945,15 +1945,15 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ Bordure et arrière-plan - {{cssxref("background")}} - Oui - Oui + {{cssxref("background")}} + Oui + Oui   - {{cssxref("border-radius")}} - Partiel[1] - Partiel[1] + {{cssxref("border-radius")}} + Partiel + Partiel
                                                                                                      1. IE9 ne prend pas en charge cette propriété.
                                                                                                      2. @@ -1961,9 +1961,9 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_ - {{cssxref("box-shadow")}} - Partiel[1] - Partiel[1] + {{cssxref("box-shadow")}} + Partiel + Partiel
                                                                                                        1. IE9 ne prend pas en charge cette propriété.
                                                                                                        2. @@ -1979,7 +1979,7 @@ original_slug: Web/Guide/HTML/Formulaires/Property_compatibility_table_for_form_
                                                                                                          • Mon premier formulaire HTML
                                                                                                          • -
                                                                                                          • Comment structurer un formulaire HTML
                                                                                                          • +
                                                                                                          • Comment structurer un formulaire HTML
                                                                                                          • Les widgets natifs pour formulaire
                                                                                                          • Envoi des données de formulaire
                                                                                                          • Validation des données de formulaire
                                                                                                          • diff --git a/files/fr/learn/forms/sending_and_retrieving_form_data/index.html b/files/fr/learn/forms/sending_and_retrieving_form_data/index.html index 9585d26c64..c2736e9d5b 100644 --- a/files/fr/learn/forms/sending_and_retrieving_form_data/index.html +++ b/files/fr/learn/forms/sending_and_retrieving_form_data/index.html @@ -17,9 +17,9 @@ original_slug: Web/Guide/HTML/Formulaires/Envoyer_et_extraire_les_données_des_f ---
                                                                                                            {{LearnSidebar}}{{PreviousMenu("Learn/Forms/Form_validation", "Learn/Forms")}}
                                                                                                            -

                                                                                                            Cet article examine ce qui arrive quand un utilisateur soumet un formulaire — où les données vont-elles et comment les gère-t-on une fois à destination ? Nous examinerons aussi quelques problèmes de sécurité associés à l'envoi des données d'un formulaire.

                                                                                                            +

                                                                                                            Cet article examine ce qui arrive quand un utilisateur soumet un formulaire — où les données vont-elles et comment les gère-t-on une fois à destination ? Nous examinerons aussi quelques problèmes de sécurité associés à l'envoi des données d'un formulaire.

                                                                                                            - +
                                                                                                            @@ -42,9 +42,8 @@ original_slug: Web/Guide/HTML/Formulaires/Envoyer_et_extraire_les_données_des_f

                                                                                                            Côté client, un formulaire HTML n'est rien d'autre qu'un moyen commode et convivial de configurer une requête HTTP pour envoyer des données à un serveur. L'utilisateur peut ainsi adresser des informations à joindre à la requête HTTP.

                                                                                                            -
                                                                                                            -

                                                                                                            Note :

                                                                                                            -

                                                                                                            Pour une meilleure idée du fonctionnement de l'architecture client‑serveur, lisez notre module Programmation d'un site web côté‑serveur : premiers pas.

                                                                                                            +
                                                                                                            +

                                                                                                            Note : Pour une meilleure idée du fonctionnement de l'architecture client‑serveur, lisez notre module Programmation d'un site web côté‑serveur : premiers pas.

                                                                                                            Côté client : définition de la méthode d'envoi des données

                                                                                                            @@ -71,9 +70,8 @@ original_slug: Web/Guide/HTML/Formulaires/Envoyer_et_extraire_les_données_des_f
                                                                                                            <form action="#">
                                                                                                            -
                                                                                                            -

                                                                                                            Note :

                                                                                                            -

                                                                                                            Il est possible de spécifier une URL qui utilise le protocole HTTPS (HTTP sécurisé). Quand vous faites ceci, les données sont chiffrées avec le reste de la requête, même si le formulaire lui-même est hébergé dans une page non sécurisée à laquelle on accède via HTTP. D'autre part, si le formulaire est hébergé sur une page sécurisée mais qu'on spécifie une URL non sécurisée avec l'attribut action, tous les navigateurs affichent une alerte de sécurité pour l'utilisateur chaque fois qu'il envoie des données car celles-ci ne sont pas chiffrées.

                                                                                                            +
                                                                                                            +

                                                                                                            Note : Il est possible de spécifier une URL qui utilise le protocole HTTPS (HTTP sécurisé). Quand vous faites ceci, les données sont chiffrées avec le reste de la requête, même si le formulaire lui-même est hébergé dans une page non sécurisée à laquelle on accède via HTTP. D'autre part, si le formulaire est hébergé sur une page sécurisée mais qu'on spécifie une URL non sécurisée avec l'attribut action, tous les navigateurs affichent une alerte de sécurité pour l'utilisateur chaque fois qu'il envoie des données car celles-ci ne sont pas chiffrées.

                                                                                                            L'attribut method

                                                                                                            @@ -118,9 +116,8 @@ original_slug: Web/Guide/HTML/Formulaires/Envoyer_et_extraire_les_données_des_f
                                                                                                            GET /?say=Hi&to=Mom HTTP/1.1
                                                                                                             Host: foo.com
                                                                                                            -
                                                                                                            -

                                                                                                            Note :

                                                                                                            -

                                                                                                            Vous trouverez cet exemple sur GitHub — voyez get-method.html (à voir directement aussi).

                                                                                                            +
                                                                                                            +

                                                                                                            Note : Vous trouverez cet exemple sur GitHub — voyez get-method.html (à voir directement aussi).

                                                                                                            La méthode POST

                                                                                                            @@ -154,9 +151,8 @@ say=Hi&to=Mom

                                                                                                            L'en-tête Content-Length indique la taille du corps, et l'en-tête Content-Type indique le type de ressources envoyées au serveur. Nous discuterons de ces en-têtes dans un moment.

                                                                                                            -
                                                                                                            -

                                                                                                            Note :

                                                                                                            -

                                                                                                            Vous trouverez cet exemple sur GitHub — voyez post-method.html (à voir directement aussi).

                                                                                                            +
                                                                                                            +

                                                                                                            Note : Vous trouverez cet exemple sur GitHub — voyez post-method.html (à voir directement aussi).

                                                                                                            Voir les requêtes HTTP

                                                                                                            @@ -202,10 +198,9 @@ say=Hi&to=Mom

                                                                                                            L'exécution du code PHP déclenche l'affichage de Hi Mom

                                                                                                            -
                                                                                                            -

                                                                                                            Note :

                                                                                                            -

                                                                                                            Cet exemple ne fonctionnera pas si vous le chargez localement dans un navigateur — les navigateurs ne savent pas interpréter le code PHP, donc quand le formulaire est soumis, le navigateur vous offrira seulement de télécharger le fichier PHP pour vous. Pour qu'il s'exécute, il est nécessaire de lancer l'exemple par l'intermédiaire d'un serveur PHP de n'importe quel type. Les bons choix pour des tests locaux de PHP sont MAMP (Mac et Windows) et AMPPS (Mac, Windows, Linux).

                                                                                                            -

                                                                                                            Notez également que si vous utilisez MAMP mais que vous n'avez pas installé MAMP Pro (ou si le temps d'essai de la démo de MAMP Pro a expiré), vous pourriez avoir des difficultés à le faire fonctionner. Pour le faire fonctionner à nouveau, nous avons constaté que vous pouvez charger l'application MAMP, puis choisir les options de menu MAMP > Préférences > PHP, et définir "Version standard :" à "7.2.x" (x sera différent selon la version que vous avez installée).

                                                                                                            +
                                                                                                            +

                                                                                                            Note : Cet exemple ne fonctionnera pas si vous le chargez localement dans un navigateur — les navigateurs ne savent pas interpréter le code PHP, donc quand le formulaire est soumis, le navigateur vous offrira seulement de télécharger le fichier PHP pour vous. Pour qu'il s'exécute, il est nécessaire de lancer l'exemple par l'intermédiaire d'un serveur PHP de n'importe quel type. Les bons choix pour des tests locaux de PHP sont MAMP (Mac et Windows) et AMPPS (Mac, Windows, Linux).

                                                                                                            +

                                                                                                            Notez également que si vous utilisez MAMP mais que vous n'avez pas installé MAMP Pro (ou si le temps d'essai de la démo de MAMP Pro a expiré), vous pourriez avoir des difficultés à le faire fonctionner. Pour le faire fonctionner à nouveau, nous avons constaté que vous pouvez charger l'application MAMP, puis choisir les options de menu MAMP > Préférences > PHP, et définir "Version standard :" à "7.2.x" (x sera différent selon la version que vous avez installée).

                                                                                                            Exemple: Python

                                                                                                            @@ -233,9 +228,8 @@ if __name__ == "__main__":
                                                                                                          • greeting.html : Ce modèle contient juste une ligne qui renvoie les deux éléments de donnée qui lui sont passées lors du rendu. Cela est effectué par l'intermédiaire de la fonction hello() vue plus haut qui s'exécute quand l'URL /hello est chargée dans le navigateur.
                                                                                                          • -
                                                                                                            -

                                                                                                            Note :

                                                                                                            -

                                                                                                            À nouveau, ce code ne fonctionnera pas si vous tentez de le charger directement dans le navigateur. Python fonctionne un peu différemment de PHP — pour exécuter ce code localement il est nécessaire d'installer Python/PIP, puis Flask avec « pip3 install flask ». À ce moment‑là vous pourrez exécuter l'exemple avec « python3 python-example.py », puis en allant sur « localhost:5000 » dans votre navigateur.

                                                                                                            +
                                                                                                            +

                                                                                                            Note : À nouveau, ce code ne fonctionnera pas si vous tentez de le charger directement dans le navigateur. Python fonctionne un peu différemment de PHP — pour exécuter ce code localement il est nécessaire d'installer Python/PIP, puis Flask avec « pip3 install flask ». À ce moment‑là vous pourrez exécuter l'exemple avec « python3 python-example.py », puis en allant sur « localhost:5000 » dans votre navigateur.

                                                                                                            Autres langages et canevas de structures

                                                                                                            @@ -253,9 +247,8 @@ if __name__ == "__main__":

                                                                                                            Enfin il faut noter que même en utilisant ces canevas, travailler avec des formulaires n'est pas toujours facile. Mais c'est quand même bien plus facile que d'essayer d'en écrire vous‑même les fonctionnalités et cela vous économisera pas mal de temps.

                                                                                                            -
                                                                                                            -

                                                                                                            Note :

                                                                                                            -

                                                                                                            Nous déborderions du cadre de cet article en vous initiant aux langages côté serveur ou aux canevas. Les liens ci‑dessus vous donneront des informations si vous souhaitez en apprendre plus.

                                                                                                            +
                                                                                                            +

                                                                                                            Note : Nous déborderions du cadre de cet article en vous initiant aux langages côté serveur ou aux canevas. Les liens ci‑dessus vous donneront des informations si vous souhaitez en apprendre plus.

                                                                                                            Cas particulier : envoyer des fichiers

                                                                                                            @@ -286,9 +279,8 @@ if __name__ == "__main__": </div> </form> -
                                                                                                            -

                                                                                                            Note :

                                                                                                            -

                                                                                                            Les serveurs peuvent être configurés avec une limite de taille pour les fichiers et les requêtes HTTP afin d'éviter les abus.

                                                                                                            +
                                                                                                            +

                                                                                                            Note : Les serveurs peuvent être configurés avec une limite de taille pour les fichiers et les requêtes HTTP afin d'éviter les abus.

                                                                                                            Problèmes courants de sécurité

                                                                                                            @@ -331,7 +323,7 @@ if __name__ == "__main__":
                                                                                                            • Mon premier formulaire HTML
                                                                                                            • -
                                                                                                            • Comment structurer un formulaire HTML
                                                                                                            • +
                                                                                                            • Comment structurer un formulaire HTML
                                                                                                            • Les widgets natifs pour formulaire
                                                                                                            • Les types de saisie HTML5
                                                                                                            • Autres contrôles de formulaires
                                                                                                            • diff --git a/files/fr/learn/forms/sending_forms_through_javascript/index.html b/files/fr/learn/forms/sending_forms_through_javascript/index.html index 73a9f6e15b..571ede2a5b 100644 --- a/files/fr/learn/forms/sending_forms_through_javascript/index.html +++ b/files/fr/learn/forms/sending_forms_through_javascript/index.html @@ -6,7 +6,7 @@ original_slug: Web/Guide/HTML/Formulaires/Sending_forms_through_JavaScript ---
                                                                                                              {{LearnSidebar}}{{PreviousMenuNext("Web/Guide/HTML/Formulaires/Comment_construire_des_widgets_de_formulaires_personnalisés", "Web/Guide/HTML/Formulaires/HTML_forms_in_legacy_browsers", "Web/Guide/HTML/Formulaires")}}
                                                                                                              -

                                                                                                              Comme dans le précédent article, les formulaires HTML peuvent envoyer une requête HTTP par déclaration. Mais des formulaires peuvent aussi préparer une requête HTTP à adresser via JavaScript. Cet article explore comment faire cela.

                                                                                                              +

                                                                                                              Comme dans le précédent article, les formulaires HTML peuvent envoyer une requête HTTP par déclaration. Mais des formulaires peuvent aussi préparer une requête HTTP à adresser via JavaScript. Cet article explore comment faire cela.

                                                                                                              Un formulaire n'est pas toujours un <form>

                                                                                                              @@ -22,7 +22,7 @@ original_slug: Web/Guide/HTML/Formulaires/Sending_forms_through_JavaScript

                                                                                                              Comment est-ce différent ?

                                                                                                              -

                                                                                                              AJAX utilise l'objet DOM {{domxref("XMLHttpRequest")}} (XHR).Il peut construire des requêtes HTTP, les envoyer et retrouver leur résultats.

                                                                                                              +

                                                                                                              AJAX utilise l'objet DOM {{domxref("XMLHttpRequest")}} (XHR).Il peut construire des requêtes HTTP, les envoyer et retrouver leur résultats.

                                                                                                              Note : Les techniques AJAX anciennes ne se fondaient pas forcément sur {{domxref("XMLHttpRequest")}}. Par exemple, JSONP combiné à la fonction eval(). Cela fonctionne, mais n'est pas recommandé en raison de sérieux problèmes de sécurité. La seule raison d'en poursuivre l'utilisation est l'utilisation de navigateurs anciens qui ne prennent pas en charge {{domxref("XMLHttpRequest")}} ou JSON, mais ce sont vraiment des navigateurs anciens ! Évitez ces techniques.

                                                                                                              @@ -206,7 +206,7 @@ original_slug: Web/Guide/HTML/Formulaires/Sending_forms_through_JavaScript

                                                                                                              La plus ancienne façon d'expédier des données de formulaire de manière asynchrone consiste à construire un formulaire avec l'API DOM, puis d'envoyer ses données dans un {{HTMLElement("iframe")}} caché. Pour accéder au résultat de votre envoi, il suffit de récupérer le contenu de l'élément {{HTMLElement("iframe")}}.

                                                                                                              -

                                                                                                              Avertissement : Évitez d'employer cette technique. Il y a des risques concernant la sécurité avec des services tierce-partie car vous laissez ouverte la possibilité d'une attaque par injection de script. Si vous utilisez HTTPS, il reste possible de perturber la politique de la même origine, ce qui peut rendre le contenu de l'élément {{HTMLElement("iframe")}} inatteignable. Toutefois, cette méthode peut être votre seule possibilité si vous devez prendre en charge des navigateurs très anciens.

                                                                                                              +

                                                                                                              Attention : Évitez d'employer cette technique. Il y a des risques concernant la sécurité avec des services tierce-partie car vous laissez ouverte la possibilité d'une attaque par injection de script. Si vous utilisez HTTPS, il reste possible de perturber la politique de la même origine, ce qui peut rendre le contenu de l'élément {{HTMLElement("iframe")}} inatteignable. Toutefois, cette méthode peut être votre seule possibilité si vous devez prendre en charge des navigateurs très anciens.

                                                                                                              Voici un exemple :

                                                                                                              @@ -260,7 +260,7 @@ function sendData(data) {

                                                                                                               

                                                                                                              -

                                                                                                              Gestion des données binaires

                                                                                                              +

                                                                                                              Gestion des données binaires

                                                                                                              Si vous utilisez un objet {{domxref("XMLHttpRequest/FormData", "FormData")}} avec un formulaire qui inclut des widgets <input type="file">, les données seront traitées automatiquement. Mais pour envoyer des données binaires à la main, il y a un travail supplémentaire à faire.

                                                                                                              @@ -428,7 +428,7 @@ window.addEventListener('load', function () {
                                                                                                              • Mon premier formulaire HTML
                                                                                                              • -
                                                                                                              • Comment structurer un formulaire HTML
                                                                                                              • +
                                                                                                              • Comment structurer un formulaire HTML
                                                                                                              • Les widgets natifs pour formulaire
                                                                                                              • Envoi des données de formulaire
                                                                                                              • Validation des données de formulaire
                                                                                                              • diff --git a/files/fr/learn/forms/styling_web_forms/index.html b/files/fr/learn/forms/styling_web_forms/index.html index ea8b60a29b..95ddead893 100644 --- a/files/fr/learn/forms/styling_web_forms/index.html +++ b/files/fr/learn/forms/styling_web_forms/index.html @@ -81,7 +81,7 @@ original_slug: Web/Guide/HTML/Formulaires/Apparence_des_formulaires_HTML -webkit-appearance: none; } -

                                                                                                                This is a screenshot of a search filed on Chrome, with and without the use of -webkit-appearance

                                                                                                                +

                                                                                                                This is a screenshot of a search filed on Chrome, with and without the use of -webkit-appearance

                                                                                                                Comme vous pouvez le voir sur la capture d'écran pour Chrome, les deux champs ont une bordure, mais le premier champ n'utilise pas la propriété -webkit-appearance tandis que le second a recours à la propriété -webkit-appearance:none. La différence est notable.

                                                                                                                @@ -96,7 +96,7 @@ original_slug: Web/Guide/HTML/Formulaires/Apparence_des_formulaires_HTML

                                                                                                                La capture d'écran ci-dessous montre les différences. Sur la gauche il y a l'affichage par défaut de Firefox pour Mac OS X, avec les réglages de police par défaut du système. Sur la droite, les mêmes éléments avec la règle d'harmonisation utilisée.

                                                                                                                -

                                                                                                                This is a screenshot of the main form widgets on Firefox on Mac OSX, with and without font harmonization

                                                                                                                +

                                                                                                                This is a screenshot of the main form widgets on Firefox on Mac OSX, with and without font harmonization

                                                                                                                Il existe un débat animé sur le fait qu'un formulaire ait une meilleure apparence en utilisant les valeurs par défaut du système d'exploitation ou en utilisant des valeurs unifiant l'apparence. C'est à vous de décider en tant que designer du site ou de l'application.

                                                                                                                @@ -115,7 +115,7 @@ original_slug: Web/Guide/HTML/Formulaires/Apparence_des_formulaires_HTML box-sizing: border-box; } -

                                                                                                                This is a screenshot of the main form widgets on Chrome on Windows 7, with and without the use of box-sizing.

                                                                                                                +

                                                                                                                This is a screenshot of the main form widgets on Chrome on Windows 7, with and without the use of box-sizing.

                                                                                                                Dans la capture d'écran ci-dessous, la colonne de gauche n'utilise pas {{cssxref("box-sizing")}}, alors que la colonne de droite utilise la propriété CSS border-box. Remarquez comment tous les éléments occupent le même espace, malgré les valeurs par défaut de la plateforme pour chacun des blocs.

                                                                                                                @@ -156,7 +156,7 @@ original_slug: Web/Guide/HTML/Formulaires/Apparence_des_formulaires_HTML

                                                                                                                Regardons sur un exemple concret la façon de composer un formulaire HTML. Cela aidera à clarifier nombre de ces concepts. Nous allons construire un formulaire de contact sous forme de « carte postale » :

                                                                                                                -

                                                                                                                C'est ce que nous voulons réaliser avec le HTML et les CSS.

                                                                                                                +

                                                                                                                C'est ce que nous voulons réaliser avec le HTML et les CSS.

                                                                                                                HTML

                                                                                                                @@ -203,7 +203,7 @@ original_slug: Web/Guide/HTML/Formulaires/Apparence_des_formulaires_HTML
                                                                                                              • Allez sur le Webfont Generator de fontsquirrel.
                                                                                                              • En utilisant le formulaire, téléversez les fichiers de polices et créez un kit de polices pou le Web. Téléchargez le kit sur votre ordinateur.
                                                                                                              • Décompressez le fichier zip fourni.
                                                                                                              • -
                                                                                                              • Dans le contenu décompressé vous trouverez deux fichiers .woff et deux fichiers .woff2. Copiez ces quatre fichiers dans un répertoire nommé fonts, dans le même répertoire que ci‑dessus. Nous utilisons deux fichiers différents pour maximiser la compatibilité avec les navigateurs ; voyez notre article sur les Web fonts pour des informations plus détaillées.
                                                                                                              • +
                                                                                                              • Dans le contenu décompressé vous trouverez deux fichiers .woff et deux fichiers .woff2. Copiez ces quatre fichiers dans un répertoire nommé fonts, dans le même répertoire que ci‑dessus. Nous utilisons deux fichiers différents pour maximiser la compatibilité avec les navigateurs ; voyez notre article sur les Web fonts pour des informations plus détaillées.
                                                                                                              • Le CSS

                                                                                                                @@ -216,18 +216,18 @@ original_slug: Web/Guide/HTML/Formulaires/Apparence_des_formulaires_HTML
                                                                                                                @font-face{
                                                                                                                   font-family : "handwriting";
                                                                                                                -  src: url('fonts/journal-webfont.woff2') format('woff2'),
                                                                                                                -       url('fonts/journal-webfont.woff') format('woff');
                                                                                                                -  font-weight: normal;
                                                                                                                -  font-style: normal;
                                                                                                                +  src: url('fonts/journal-webfont.woff2') format('woff2'),
                                                                                                                +       url('fonts/journal-webfont.woff') format('woff');
                                                                                                                +  font-weight: normal;
                                                                                                                +  font-style: normal;
                                                                                                                 }
                                                                                                                 
                                                                                                                 @font-face{
                                                                                                                   font-family : "typewriter";
                                                                                                                -  src: url('fonts/veteran_typewriter-webfont.woff2') format('woff2'),
                                                                                                                -       url('fonts/veteran_typewriter-webfont.woff') format('woff');
                                                                                                                -  font-weight: normal;
                                                                                                                -  font-style: normal;
                                                                                                                +  src: url('fonts/veteran_typewriter-webfont.woff2') format('woff2'),
                                                                                                                +       url('fonts/veteran_typewriter-webfont.woff') format('woff');
                                                                                                                +  font-weight: normal;
                                                                                                                +  font-style: normal;
                                                                                                                 }
                                                                                                                 
                                                                                                                 body {
                                                                                                                @@ -327,7 +327,7 @@ form {
                                                                                                                   overflow: auto;
                                                                                                                 }
                                                                                                                -

                                                                                                                L'élément {{HTMLElement("button")}} est très accommodant avec les CSS ; vous faites ce que vous voulez, même en utilisant les pseudo-elements !

                                                                                                                +

                                                                                                                L'élément {{HTMLElement("button")}} est très accommodant avec les CSS ; vous faites ce que vous voulez, même en utilisant les pseudo-elements !

                                                                                                                button {
                                                                                                                   position     : absolute;
                                                                                                                @@ -379,7 +379,7 @@ button:focus {
                                                                                                                 
                                                                                                                 
                                                                                                                • Mon premier formulaire HTML
                                                                                                                • -
                                                                                                                • Comment structurer un formulaire HTML
                                                                                                                • +
                                                                                                                • Comment structurer un formulaire HTML
                                                                                                                • Les widgets natifs pour formulaire
                                                                                                                • Envoi des données de formulaire
                                                                                                                • Validation des données de formulaire
                                                                                                                • diff --git a/files/fr/learn/forms/your_first_form/example/index.html b/files/fr/learn/forms/your_first_form/example/index.html index 70455c78a8..d5268524e3 100644 --- a/files/fr/learn/forms/your_first_form/example/index.html +++ b/files/fr/learn/forms/your_first_form/example/index.html @@ -6,7 +6,7 @@ original_slug: Web/Guide/HTML/Formulaires/Mon_premier_formulaire_HTML/Exemple ---

                                                                                                                  Ceci est l'exemple pour l'article Mon premier formulaire HTML.

                                                                                                                  -

                                                                                                                  Un formulaire simple

                                                                                                                  +

                                                                                                                  Un formulaire simple

                                                                                                                  Contenu HTML

                                                                                                                  diff --git a/files/fr/learn/forms/your_first_form/index.html b/files/fr/learn/forms/your_first_form/index.html index ca8631cf21..4ee759f619 100644 --- a/files/fr/learn/forms/your_first_form/index.html +++ b/files/fr/learn/forms/your_first_form/index.html @@ -15,9 +15,9 @@ original_slug: Web/Guide/HTML/Formulaires/Mon_premier_formulaire_HTML ---

                                                                                                                  {{LearnSidebar}}{{NextMenu("Web/Guide/HTML/Formulaires/Comment_structurer_un_formulaire_HTML", "Web/Guide/HTML/Formulaires")}}

                                                                                                                  -

                                                                                                                  Le premier article de notre série vous offre une toute première expérience de création de formulaire en HTML, y compris sa conception, sa mise en œuvre en utilisant les bons éléments HTML, l'ajout de quelques très simples décorations avec les CSS et la façon dont les données sont envoyées à un serveur.

                                                                                                                  +

                                                                                                                  Le premier article de notre série vous offre une toute première expérience de création de formulaire en HTML, y compris sa conception, sa mise en œuvre en utilisant les bons éléments HTML, l'ajout de quelques très simples décorations avec les CSS et la façon dont les données sont envoyées à un serveur.

                                                                                                                  -
                                                                                                            Prérequis :
                                                                                                            +
                                                                                                            @@ -49,7 +49,7 @@ original_slug: Web/Guide/HTML/Formulaires/Mon_premier_formulaire_HTML

                                                                                                            Dans ce guide, nous allons concevoir un formulaire de contact simple. Posons les premières pierres.

                                                                                                            -

                                                                                                            Le croquis du formulaire que l'on veut créer

                                                                                                            +

                                                                                                            Le croquis du formulaire que l'on veut créer

                                                                                                            Notre formulaire contiendra trois champs de texte et un bouton. Nous demandons simplement à notre utilisateur son nom, son adresse électronique et le message qu'il souhaite envoyer. En appuyant sur le bouton, le message sera envoyé au serveur web.

                                                                                                            @@ -63,7 +63,7 @@ original_slug: Web/Guide/HTML/Formulaires/Mon_premier_formulaire_HTML

                                                                                                            Tous les formulaires HTML débutent par un élément {{HTMLElement("form")}} comme celui-ci :

                                                                                                            -
                                                                                                            <form action="/my-handling-form-page" method="post">
                                                                                                            +
                                                                                                            <form action="/my-handling-form-page" method="post">
                                                                                                             
                                                                                                             </form>
                                                                                                            @@ -86,7 +86,7 @@ original_slug: Web/Guide/HTML/Formulaires/Mon_premier_formulaire_HTML

                                                                                                            En terme de code HTML, nous avons besoin de quelque chose qui ressemble à ceci pour mettre en œuvre nos widgets de formulaire.

                                                                                                            -
                                                                                                            <form action="/ma-page-de-traitement" method="post">
                                                                                                            +
                                                                                                            <form action="/ma-page-de-traitement" method="post">
                                                                                                                 <div>
                                                                                                                     <label for="name">Nom :</label>
                                                                                                                     <input type="text" id="name" name="user_name">
                                                                                                            @@ -112,17 +112,17 @@ original_slug: Web/Guide/HTML/Formulaires/Mon_premier_formulaire_HTML
                                                                                                             
                                                                                                             

                                                                                                            Last but not least, remarquez la syntaxe de <input> vs <textarea></textarea>. C'est une des bizarreries du HTML. La balise <input> est un élément vide, ce qui signifie qu'il n'a pas besoin de balise fermante. Au contraire, {{HTMLElement("textarea")}} n'est pas un élément vide, il faut donc le fermer avec la balise fermante appropriée. Cela a un effet sur une caractéristique spécifique des formulaires HTML : la manière dont vous définissez la valeur par défaut. Pour définir une valeur par défaut d'un élément {{HTMLElement("input")}} vous devez utiliser l'attribut value de la manière suivante :

                                                                                                            -
                                                                                                            <input type="text" value="par défaut cet élément sera renseigné avec ce texte">
                                                                                                            +
                                                                                                            <input type="text" value="par défaut cet élément sera renseigné avec ce texte">

                                                                                                            A contrario, si vous souhaitez définir la valeur par défaut d'un élément {{HTMLElement("textarea")}}, il suffit simplement de mettre la valeur par défaut entre les balises ouvrantes et fermantes de l'élément {{HTMLElement("textarea")}} de la manière suivante :

                                                                                                            -
                                                                                                            <textarea>par défaut cet élément sera renseigné avec ce texte</textarea>
                                                                                                            +
                                                                                                            <textarea>par défaut cet élément sera renseigné avec ce texte</textarea>

                                                                                                            L'élément {{HTMLElement("button")}}

                                                                                                            Notre formulaire est presque terminé. Il nous suffit seulement d'ajouter un bouton pour permettre à l'utilisateur de nous envoyer les données renseignées dans le formulaire. Ceci se fait simplement en ajoutant d'un élément {{HTMLElement("button")}} ; ajoutez‑le juste avant la balise fermante </form> :

                                                                                                            -
                                                                                                                <div class="button">
                                                                                                            +
                                                                                                                <div class="button">
                                                                                                                     <button type="submit">Envoyer le message</button>
                                                                                                                 </div>
                                                                                                             
                                                                                                            @@ -136,30 +136,30 @@ original_slug: Web/Guide/HTML/Formulaires/Mon_premier_formulaire_HTML
                                                                                                            -

                                                                                                            Note : Vous pouvez aussi utiliser l'élément {{HTMLElement("input")}} avec le type approprié pour produire un bouton, par exemple <input type="submit">. Le principal avantage de {{HTMLElement("button")}} par rapport à l'élément {{HTMLElement("input")}} est que ce dernier ne permet d'utiliser que du texte comme étiquette tandis que l'élément {{HTMLElement("button")}} permet d'utiliser n'importe quel contenu HTML, autorisant ainsi des textes de bouton plus complexes et créatifs.

                                                                                                            +

                                                                                                            Note : Vous pouvez aussi utiliser l'élément {{HTMLElement("input")}} avec le type approprié pour produire un bouton, par exemple <input type="submit">. Le principal avantage de {{HTMLElement("button")}} par rapport à l'élément {{HTMLElement("input")}} est que ce dernier ne permet d'utiliser que du texte comme étiquette tandis que l'élément {{HTMLElement("button")}} permet d'utiliser n'importe quel contenu HTML, autorisant ainsi des textes de bouton plus complexes et créatifs.

                                                                                                            Mise en page élémentaire du formulaire

                                                                                                            Nous avons désormais notre formulaire HTML, et si vous le regardez dans votre navigateur préféré, vous verrez qu'il est plutôt laid.

                                                                                                            -

                                                                                                            +

                                                                                                            -

                                                                                                            Note : Si vous pensez que vous n'avez pas écrit un code HTML correct, faites la comparaison avec celui de notre exemple terminé — voyez  first-form.html ( ou également directement).

                                                                                                            +

                                                                                                            Note : Si vous pensez que vous n'avez pas écrit un code HTML correct, faites la comparaison avec celui de notre exemple terminé — voyez  first-form.html ( ou également directement).

                                                                                                            Les formulaires sont notoirement embêtants à présenter joliment. Apprendre la mise en page ou la décoration des formulaires sort du cadre de cet article, donc pour le moment nous allons simplement ajouter quelques indications au CSS pour lui donner un air convenable.

                                                                                                            Tout d'abord, ajoutons un élément {{htmlelement("style")}} à notre page, dans l'en‑tête HTML. Comme ceci :

                                                                                                            -
                                                                                                            <style>
                                                                                                            +
                                                                                                            <style>
                                                                                                             
                                                                                                             </style>

                                                                                                            Entre les balises style, ajoutons le CSS suivant, juste comme indiqué :

                                                                                                            -
                                                                                                            form {
                                                                                                            +
                                                                                                            form {
                                                                                                               /* Uniquement centrer le formulaire sur la page */
                                                                                                               margin: 0 auto;
                                                                                                               width: 400px;
                                                                                                            @@ -219,10 +219,10 @@ button {
                                                                                                             
                                                                                                             

                                                                                                            Désormais notre formulaire a une bien meilleure allure.

                                                                                                            -

                                                                                                            +

                                                                                                            -

                                                                                                            Note : Il est sur GitHub dans first-form-styled.html (à voir aussi directement).

                                                                                                            +

                                                                                                            Note : Il est sur GitHub dans first-form-styled.html (à voir aussi directement).

                                                                                                            Envoyer les données au serveur Web

                                                                                                            @@ -235,7 +235,7 @@ button {

                                                                                                            Pour nommer vos données vous devez utiliser l'attribut name pour identifier bien précisément l'élément d'information collecté par chacun des widgets. Regardons à nouveau le code de notre formulaire :

                                                                                                            -
                                                                                                            form action="/my-handling-form-page" method="post">
                                                                                                            +
                                                                                                            form action="/my-handling-form-page" method="post">
                                                                                                               <div>
                                                                                                                 <label for="name">Nom :</label>
                                                                                                                 <input type="text" id="name" name="user_name" />
                                                                                                            -- 
                                                                                                            cgit v1.2.3-54-g00ecf
                                                                                                            
                                                                                                            
                                                                                                            Prérequis :