Movatterモバイル変換


[0]ホーム

URL:


  1. Web
  2. HTML
  3. Référence
  4. Éléments
  5. <input>
  6. <input type="range">

Cette page a été traduite à partir de l'anglais par la communauté.Vous pouvez contribuer en rejoignant la communauté francophone sur MDN Web Docs.

View in EnglishAlways switch to English

<input type="range">

Baseline Widely available *

Cette fonctionnalité est bien établie et fonctionne sur de nombreux appareils et versions de navigateurs. Elle est disponible sur tous les navigateurs depuis mars 2017.

* Certaines parties de cette fonctionnalité peuvent bénéficier de prise en charge variables.

Les éléments<input> dont l'attributtype vautrange permettent à l'utilisatrice ou l'utilisateur d'indiquer une valeur numérique comprise entre deux bornes. La valeur précise n'est pas considérée comme importante. Ces éléments sont généralement représentés avec un curseur sur une ligne ou comme un bouton de potentiel et non pas comme un champ de saisie (à la façon denumber par exemple).

Ce genre dewidget n'étant pas précis, ce type ne devrait pas être utilisé lorsque la valeur exacte fournie est importante.

Exemple interactif

<p>Audio settings:</p><div>  <input type="range" name="volume" min="0" max="11" />  <label for="volume">Volume</label></div><div>  <input    type="range"       name="cowbell"    min="0"    max="100"    value="90"    step="10" />  <label for="cowbell">Cowbell</label></div>
p,label {  font:    1rem "Fira Sans",    sans-serif;}input {  margin: 0.4rem;}

Si le navigateur de l'utilisatrice ou l'utilisateur ne prend pas en charge le typerange, il utilisera le typetext à la place.

Valeur Une chaîne de caractères (DOMString) qui contient la représentation textuelle de la valeur numérique sélectionnée. On utilisera la méthodevalueAsNumber afin d'obtenir la valeur sous forme numérique (typeNumber).
Évènementschange etinput
Attributs pris en chargeautocomplete,list,max,min, etstep
Attributs IDLlist,value etvalueAsNumber
MéthodesstepDown() etstepUp()

Validation

Il n'existe pas de motif de validation. Cependant, voici les formes de validation automatiques qui sont appliquées :

  • Si la valeur de l'attributvalue est quelque chose qui ne peut pas être converti en nombre décimal, la validation échoue.
  • La valeur ne doit pas être inférieure àmin. La valeur minimale par défaut est0.
  • La valeur ne doit pas être supérieure àmax. La valeur maximale par défaut est0.
  • La valeur doit être un multiple destep. La valeur par défaut est1.

Valeur

L'attributvalue contient une chaîne de caractèresDOMString qui correspond à la représentation textuelle du nombre sélectionnée. La valeur n'est jamais une chaîne vide (""). La valeur par défaut est celle médiane entre le minimum et le maximum (sauf si la valeur maximale indiquée est inférieure à la valeur minimale, auquel cas la valeur par défaut est celle de l'attributmin). Voici un fragment de code illustrant cet algorithme pour le choix de la valeur par défaut :

js
defaultValue =  rangeElem.max < rangeElem.min    ? rangeElem.min    : rangeElem.min + (rangeElem.max - rangeElem.min) / 2;

Si on essaie d'obtenir une valeur inférieure au minimum, alors la valeur sera ramenée au minimum (de même si on essaye de dépasser le maximum).

Attributs supplémentaires

En complément des attributs communs à l'ensemble des éléments<input>, les champs pour les intervalles peuvent utiliser les attributs suivants :

list

La valeur de cet attribut est l'identifiant (id) d'un élément<datalist> situé dans le même document. L'élément<datalist> fournit une liste de valeurs prédéfinies qui doivent être suggérées lors de la saisie dans le champ. Toute valeur de cette liste qui n'est pas compatible avec le type de champ (type) ne sera pas incluse dans les suggestions. Les valeurs fournies sont des suggestions et pas des contraintes : il reste tout à fait possible de choisir une valeur différente que celles de la liste.

Voir l'exemple ci-après surle contrôle d'intervalle avec les marques qui illustre comment ces options s'affichent dans les navigateurs qui prennent en charge la fonctionnalité.

max

La plus grande valeur autorisée sur l'intervalle. Si la valeur saisie dans le champ (représentée par l'attributvalue) dépasse ce seuil,la validation échouera. Si la valeur fournie n'est pas un nombre, aucun maximum ne sera fixé pour la valeur du contrôle.

Cette valeur doit être supérieure ou égale à celle indiquée par l'attributmin. Voir l'attribut HTMLmax.

min

La plus petite valeur autorisée sur l'intervalle. Si la valeur saisie dans le champ (représentée par l'attributvalue) est inférieure à ce seuil,la validation échouera. Si la valeur fournie n'est pas un nombre, aucun minimum ne sera fixé pour la valeur du contrôle.

Cette valeur doit être inférieure ou égale à celle indiquée par l'attributmax. Voir l'attribut HTMLmin.

step

L'attributstep est un nombre qui définit la granularité à laquelle la valeur doit obéir, ou la valeurany (décrite ci-après). Seules les valeurs qui sont des incréments en multiple destep depuis la valeur de base (min si cet attribut est défini,value sinon, et si aucun n'est fourni, une valeur par défaut appropriée) sont valides.

Si cet attribut utilise la chaîne de caractèreany, cela signifie qu'il n'y a aucune contrainte d'incrément et que toute valeur est autorisée (sous réserve de respecter les autres contraintes, comme celles indiquées parmin etmax).

Note :Lorsque les données saisies dans le contrôle ne respectent pas l'incrément,l'agent utilisateur pourra arrondir à la valeur valide la plus proche, en privilégiant les nombres les plus grands si les deux options valides environnantes sont à égale distance.

Par défaut, l'incrément utilisé pour les champs de typerange vaut 1 et on ne peut alors saisir que des entiers à moins que la valeur de base ne soit pas entière. Ainsi, si on définitmin avec -10 etvalue avec 1.5, un attributstep qui vaut 1 permettra de saisir les valeurs positives 1.5, 2.5, 3.5, etc. et les valeurs négatives -0.5, -1.5, -2.5, etc.

Voirl'attribut HTMLstep.

Attributs non-standard

orient

Semblable à la propriété CSS non-standardmoz-orient qui agit sur les éléments<progress> et<meter>, l'attributorient définit l'orientation de la piste pour le contrôle d'intervalle. Les valeurs possibles incluenthorizontal pour un affichage horizontal etvertical pour un affichage vertical.

Note :Les attributs suivants ne s'appliquent pas aux contrôles d'intervalle (<input type="range">) :accept,alt,checked,dirname,formaction,formenctype,formmethod,formnovalidate,formtarget,height,maxlength,minlength,multiple,pattern,placeholder,readonly,required,size,src, etwidth. Si l'un de ces attributs est inclus, il sera ignoré.

Exemples

Bien que le typenumber permette à l'utilisatrice ou l'utilisateur de saisir un nombre avec certaines contraintes optionnelles (par exemple, pour que la valeur soit comprise entre un minimum et un maximum), ce type nécessite de saisir une valeur spécifique. Le typerange permet de saisir une valeur lorsque l'exactitude de celle-ci importe peu.

Voici quelques scénarios où un contrôle de saisie avec un intervalle est plus pertinent :

  • Les contrôles relatifs à l'audio pour le volume, la balance ou les filtres.
  • Les contrôles relatifs à la configuration des couleurs (canaux, transparence, luminosité, etc.).
  • Les contrôles relatifs à la configuration de jeux vidéos (difficulté, distance de visibilité, taille du monde généré, etc.).
  • La longueur du mot de passe pour les mots de passe générés par un gestionnaire de mots de passe.

De façon générale, si une utilisatrice ou un utilisateur est plutôt intéressé dans un pourcentage représentant la distance entre la borne minimale et la borne maximale, un intervalle de saisie sera plus pertinent (par exemple, pour le volume, on pensera plutôt « augmenter le volume jusqu'à la moitié du maximum » que « mettre le volume à 0.5 »).

Indiquer le minimum et le maximum

Par défaut, le minimum vaut0 et le maximum vaut100. Si ces bornes ne conviennent pas, on peut facilement les changer via les attributsmin et/oumax. Ces attributs acceptent des nombres décimaux.

Par exemple, afin de demander à une utilisatrice ou un utilisateur de choisir une valeur approximative dans l'intervalle[-10, 10], on pourra utiliser :

html
<input type="range" min="-10" max="10" />

Définir la granularité

Par défaut, la granularité vaut1, ce qui signifie que la valeur est toujours un entier. Cela peut être modifié grâce à l'attributstep qui permet de contrôler la granularité. Ainsi, si on souhaite une valeur comprise entre5 et10 et précise avec deux chiffres après la virgule, on pourra utiliser l'attributstep avec la valeur0.01 :

Utiliser l'attributstep

html
<input type="range" min="5" max="10" step="0.01" />

Utiliser l'attributstep avecany

Si on souhaite prendre en charge n'importe quelle valeur, quel que soit le nombre de décimales, on pourra utiliser la valeurany pour l'attributstep :

html
<input type="range" min="0" max="3.14" step="any" />

Cet exemple permet de choisir une valeur entre0 et3.14 sans aucune restriction quant à la partie décimale.

Ajouter des marques et des étiquettes

La spécification HTML fournit une certaine flexibilité aux navigateurs pour représenter le contrôle de saisie. La spécification indique comment ajouter des informations pour certains niveaux de l'intervalle grâce à l'attributlist et à un élément<datalist>. En revanche, il n'y a pas de spécifications précises quant aux marques (tirets) positionnées le long du contrôle.

Aperçus

La plupart des navigateurs prennent partiellement en charge ces fonctionnalités. Voici donc quelques aperçus du résultat qui peut être obtenu sur macOS avec un navigateur qui prend en charge chacune des fonctionnalités.

Un contrôle sans marque

Voici ce qu'on obtient lorsque le navigateur ne prend pas en charge cette fonctionnalité ou que l'attributlist est absent.

HTMLExemples
html
<input type="range">
Capture d'écran
Capture d'écran d'un contrôle d'intervalle avec une piste, sans modification, sur macOS
Rendulive
Un contrôle avec des marques

Dans l'exemple qui suit, le contrôle utilise un attributlist qui indique l'identifiant d'un élément<datalist> qui définit un ensemble de marques à appliquer sur le contrôle. Il y en a ici 11 : une marque pour0% puis une marque tous les10%. Chaque point pour lequel on souhaite afficher une marque est représenté par un élément<option> dont la valeur de l'attributvalue correspond à l'emplacement de la marque.

HTMLExemples
html
<input type="range" list="tickmarks">

<datalist><option value="0"></option><option value="10"></option><option value="20"></option><option value="30"></option><option value="40"></option><option value="50"></option><option value="60"></option><option value="70"></option><option value="80"></option><option value="90"></option><option value="100"></option></datalist>

Capture d'écran
Une capture d'écran d'un contrôle d'intervalle avec des marques sur macOS
Rendulive
Un contrôle avec des marques et des étiquettes

Il est possible d'ajouter des étiquettes grâce à l'attributlabel des éléments<option> correspondants aux marques.

HTMLExemples
html
<input type="range" list="tickmarks">

<datalist><option value="0" label="0%"></option><option value="10"></option><option value="20"></option><option value="30"></option><option value="40"></option><option value="50" label="50%"></option><option value="60"></option><option value="70"></option><option value="80"></option><option value="90"></option><option value="100" label="100%"></option></datalist>

Capture d'écran
Capture d'écran d'un contrôle d'intervalle avec des marques et des libellés associés sur macOS
Rendulive

Note :Actuellement, aucun navigateur ne prend en charge l'ensemble de ces fonctionnalités. Firefox n'affiche aucune marque ni étiquette et Chrome affiche uniquement les marques mais pas les étiquettes. La version 66 (66.0.3359.181) de Chrome prendre en charge les étiquettes mais par défaut l'élément<datalist> est mis en forme avec CSS etdisplay: none;, ce qui le masque.

Créer des contrôles d'intervalle verticaux

Par défaut, si un navigateur affiche un tel contrôle avec une piste, celle-ci sera affichée afin que le curseur puisse aller de gauche à droite. Selon la prise en charge du navigateur, on pourra afficher le contrôle verticalement et déplacer le curseur vers le haut ou vers le bas en utilisant CSS en déclarant une hauteur supérieure à une largeur. Cette fonctionnalité n'est, à date, implémentée par aucun des navigateurs majeurs (voirle bug 981916 pour Firefox,le bug 341071 pour Chrome). La spécification d'un tel rendu vertical esttoujours en discussion.

En attendant, il est possible de créer un contrôle vertical en utilisant les transformations CSS ou en utilisant les méthodes spécifiques à chaque navigateur : en utilisant la propriété CSSappearance avec la valeurslider-vertical, en utilisant l'attribut non-standardorient ou en changeant l'orientation du texte pour Internet Explorer.

Contrôle d'intervalle horizontal

Prenons ce contrôle :

html
<input type="range" min="0" max="11" value="7" step="1" />

Il s'affiche horizontalement (en tout cas sur la plupart, si ce n'est la totalité, des principaux navigateurs).

Méthodes standard pour un rendu vertical

Selon la spécification, pour afficher un tel contrôle verticalement, il suffit que ses dimensions soient plus hautes que larges :

css
#volume {  height: 150px;  width: 50px;}
html
<input type="range" min="0" max="11" value="7" step="1" />

Toutefois, aucun navigateur majeur ne prend en charge cette fonctionnalité.

Utiliser les transformations CSS

On peut créer un contrôle vertical en dessinant un contrôle horizontal auquel on applique une rotation. Pour cela, on pourra utiliser CSS avectransform pour tourner l'élément. Voyons comment faire.

Tout d'abord, on enveloppe l'élément<input> dans un élément<div> afin de pouvoir corriger la disposition une fois que la transformation est effectuée (les transformations n'affectent pas automatiquement la disposition de la page) :

html
<div>  <input type="range" min="0" max="11" value="7" step="1" /></div>

En suite, on met en forme le conteneur du contrôle avec CSS en indiquant le mode d'affichage et la taille qu'on souhaite afin que la page soit organisée correctement. En pratique, cela correspond à réserver un espace sur la page afin que le curseur tourné s'inscrive dans l'espace réservé, sans perturber les autres éléments.

css
.slider-wrapper {  display: inline-block;  width: 20px;  height: 150px;  padding: 0;}

Et ensuite, on met en forme l'élément<input> situé dans cet espace réservé :

css
.slider-wrapper input {  width: 150px;  height: 20px;  margin: 0;  transform-origin: 75px 75px;  transform: rotate(-90deg);}

La taille du contrôle est de 150 pixels de long sur 20 pixels de haut. Les marges sont nulles ettransform-origin déplace au milieu de l'espace le centre de rotation (75 étant la moitié de 150). Enfin, on applique une rotation antihoraire de90°. On obtient comme résultat un contrôle d'intervalle vertical où le maximum est situé en haut et où le minimum est situé en bas.

Utiliser la propriétéappearance

La propriétéappearance possède une valeur non-standardslider-vertical qui permet de transformer les pistes horizontales en pistes verticales.

On utilise le même HTML que pour les exemples précédents :

html
<input type="range" min="0" max="11" value="7" step="1" />

Ici, on cible uniquement les contrôles d'intervalles :

css
input[type="range"] {  -webkit-appearance: slider-vertical;}

Utiliser l'attributorient

Firefox dispose d'un attribut HTML non-standard :orient.

Le code HTML est semblable à celui utilisé précédemment, on y ajoute l'attribut avec une valeurvertical :

html
<input type="range" min="0" max="11" value="7" step="1" orient="vertical" />

writing-mode: bt-lr;

La propriétéwriting-mode ne devrait pas être utilisée pour modifier la direction du texte pour l'internationalisation et la localisation mais peut être employée pour créer des effets spéciaux.

Ici, on utilise le même HTML que précédemment :

html
<input type="range" min="0" max="11" value="7" step="1" />

On cible uniquement les contrôles d'intervalle et on change leur mode d'écriture avec la valeurbt-lr qui signifiebottom-to-top and left-to-right, soit du bas vers le haut puis de la gauche vers la droite :

css
input[type="range"] {  writing-mode: bt-lr;}

Assembler tout ça

Comme chacun des exemples précédents fonctionne dans un navigateur différent, on peut les combiner en un seul qui fonctionne pour les différents navigateurs.

On garde l'attributorient avec la valeurvertical pour Firefox :

html
<input type="range" min="0" max="11" value="7" step="1" orient="vertical" />

On cible les contrôles d'intervalle avec un mode d'écriturebt-lr pour Internet Explorer et on ajoute-webkit-appearance: slider-vertical pour les navigateurs basés sur WebKit :

css
input[type="range"] {  writing-mode: bt-lr;  -webkit-appearance: slider-vertical;}

Spécifications

Specification
HTML
# range-state-(type=range)

Compatibilité des navigateurs

Voir aussi

Help improve MDN

Learn how to contribute

Cette page a été modifiée le par lescontributeurs du MDN.


[8]ページ先頭

©2009-2026 Movatter.jp