Cette page a été traduite à partir de l'anglais par la communauté.Vous pouvez contribuer en rejoignant la communauté francophone sur MDN Web Docs.
Number
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 juillet 2015.
Les valeursNumber représentent les nombres décimaux comme37 ou-9.25.
Le constructeurNumber() contient des constantes et des méthodes pour manipuler les nombres. Les valeurs des autres types peuvent être converties en nombre à l'aide de la fonctionNumber().
Dans cet article
Description
Les nombres sont généralement exprimés sous leur forme littérale comme255 ou3.14159. Lagrammaire lexicale contient une référence plus détaillée à ce sujet.
255; // deux cent cinquante-cinq255.0; // le même nombre255 === 255.0; // true255 === 0xff; // true (notation hexadécimale)255 === 0b11111111; // true (notation binaire)255 === 0.255e3; // true (notation scientifique)En JavaScript, un littéral numérique comme37 est bien une valeur décimale et pas particulièrement entière. Il n'existe pas de type entier distinct pour un usage courant (le typeBigInt existe mais sert à représenter les très grandes valeurs entières et pas les nombres courants comme37).
Quand on utiliseNumber(valeur) comme fonction, elle permet de convertir une chaîne de caractères ou une valeur d'un autre type en valeur de typeNumber. Si la valeur ne peut pas être convertie, elle renvoieNaN
Number("123"); // renvoie le nombre 123Number("123") === 123; // trueNumber("licorne"); // NaNNumber(undefined); // NaNEncodage des valeurs numériques
Le type JavaScriptNumber utiliseune représentation binaire à précision double sur 64 bits telle que décrite par le standard IEEE 754. Cela signifie que les valeurs décimales peuvent être représentées, avec certaines limites sur l'amplitude et la précision. En résumé, un nombre à précision double IEEE 754 utilise 64 bits pour représenter trois fragments :
- 1 bit pourle signe (indiquant si le nombre est positif ou négatif)
- 11 bits pourl'exposant (pouvant aller de -1022 à 1023)
- 52 bits pourla mantisse (représentant un nombre entre 0 et 1)
La mantisse est la partie qui représente la valeur effective (les chiffres significatifs). L'exposant indique la puissance de deux par laquelle la mantisse devrait être multipliée. On peut écrire la formule suivante (proche de la notation scientifique) :
La mantisse est stockée sur 52 bits, interprétés comme les chiffres de la partie fractionnaire de1.… en binaire. La précision de la mantisse est donc 2-52 (valeur qu'on peut obtenir viaNumber.EPSILON), soit entre 15 et 17 chiffres en écriture décimale. Les valeurs arithmétiques au-delà de cette précision serontarrondies.
La valeur la plus grande qui puisse être représentée par un nombre en JavaScript est 21024 - 1 (ici l'exposant vaut 1023 et la mantisse vaut 0.1111… en base 2), valeur qu'on peut obtenir avecNumber.MAX_VALUE. Les valeurs supérieures à celle-ci sont remplacées par la constante spécialeInfinity.
Les entiers peuvent uniquement être représentés sans perte de précision dans l'intervalle -253 + 1 à 253 - 1 inclus (valeurs qu'on peut obtenir avecNumber.MIN_SAFE_INTEGER etNumber.MAX_SAFE_INTEGER), car la mantisse ne peut contenir que 53 bits (en comptant le 1).
De plus amples précisions sont disponibles dansle standard ECMAScript.
Conversion numérique
De nombreuses opérations natives qui s'attendent à manipuler des nombres appliquent d'abord une conversion à leurs arguments pour les transformer en nombre (ce qui explique pourquoi les objetsNumber se comportent généralement comme des valeurs numériques primitives).Cette opération de conversion peut être résumée ainsi :
- Les nombres sont renvoyés tels quels.
undefinedest transformé enNaN.nullest transformé en0.trueest transformé en1, etfalseest transformé en0.- Les chaînes de caractères sont converties en les analysant comme si elles contenaientun littéral numérique. Toute erreur d'analyse produira
NaN. Il y a quelques différences mineures par rapport à littéral numérique :- Les blancs et fins de lignes au début ou à la fin sont ignorés.
- Un chiffre
0en début de chaîne n'indique pas un littéral en base octale (et n'est pas rejeté en mode strict). +et-sont autorisés au début de la chaîne pour indiquer le signe. Dans du code littéral, ils semblent faire partie du littéral, mais sont en réalité des opérateurs unaires distincts. Toutefois, le signe ne peut apparaître qu'une seule fois et ne pas être suivi par des blancs.Infinityet-Infinitysont reconnus comme des valeurs littérales. Dans du code réel, il s'agit de variables globales.- Les chaînes de caractères vides ou qui ne contiennent que des blancs sont converties en
0. - Les séparateurs numériques (le tiret bas dans
1_050.95) ne sont pas autorisés.
- Les grands entiers (BigInts) déclenchent une exception
TypeErrorpour empêcher une perte de précision involontaire lors de la conversion implicite. - Les symboles déclenchent une exception
TypeError - Les objets sont d'abordconvertis en une valeur primitive à l'aide de leurs méthodes
[@@toPrimitive]()(où"number"est fourni comme indication),valueOf(), ettoString(), selon cet ordre. La valeur primitive obtenue est alors convertie en nombre.
Il existe deux méthodes qui permettent de déclencher cette conversion (ou presque) en JavaScript :
- Le plus unaire :
+xapplique l'algorithme explicité avant pour convertirx. - La fonction
Number():Number(x)utilise le même algorithme pour convertirx, sauf queles grands entiers (BigInts) ne déclenchent pas d'exceptionTypeErrormais renvoient la valeur numérique correspondante, quitte à ce qu'il y ait une perte de précision.
Number.parseFloat() etNumber.parseInt() sont semblables àNumber() mais servent uniquement à convertir des chaînes de caractères, en suivant des règles légèrement différentes. Par exemple,parseInt() ne reconnaît pas le point décimal etparseFloat() ne reconnaît pas le préfixe0x.
Conversion entière
Certaines opérations s'attendent à manipuler des entiers, notamment celles qui fonctionnent avec des indices de tableaux ou de chaînes de caractères, des composantes temporelles et des bases numériques. Après la conversion numérique décrite ci-avant, le résultat esttronqué en un nombre entier (la partie fractionnaire est ignorée). Si le nombre est±Infinity, il est renvoyé tel quel. Si le nombre estNaN ou-0, c'est0 qui est renvoyé. Le résultat est donc toujours un entier (qui n'est pas-0) ou±Infinity.
On notera que, pour la conversion entière,undefined etnull deviennent0, carundefined est d'abord converti enNaN lors de la conversion numérique, puis en0 lors de la conversion entière qui suit.
Conversion en nombre à longueur fixe
Certaines fonctions JavaScript « bas-niveau » permettent de manipuler l'encodage binaire des nombres entiers, notammentles opérateurs binaires et les objetsTypedArray. Les opérateurs binaires convertissent toujours leurs opérandes en entiers sur 32 bits. Dans ces cas, après la conversion numérique décrite avant, le nombre est normalisé à la largeur souhaitée entronquant la partie fractionnaire, puis en considérant les bits les plus faibles de la représentation de l'entier en complément à deux.
new Int32Array([1.1, 1.9, -1.1, -1.9]); // Int32Array(4) [ 1, 1, -1, -1 ]new Int8Array([257, -257]); // Int8Array(2) [ 1, -1 ]// 257 = 0001 0000 0001// = 0000 0001 (mod 2^8)// = 1// -257 = 1110 1111 1111// = 1111 1111 (mod 2^8)// = -1 (comme entier signé)new Uint8Array([257, -257]); // Uint8Array(2) [ 1, 255 ]// -257 = 1110 1111 1111// = 1111 1111 (mod 2^8)// = 255 (comme entier non-signé)Constructeur
Number()Crée une nouvelle valeur
Number.
LorsqueNumber est appelé comme constructeur (avec le mot-clénew), il crée un objetNumber quin'est pas une valeur primitive. Par exemple, on auratypeof new Number(42) === "object", etnew Number(42) !== 42 (même sinew Number(42) == 42).
Attention :Il est plutôt rare de devoir utiliserNumber comme constructeur.
Propriétés statiques
Number.EPSILONLe plus petit intervalle entre deux valeurs qu'il est possible de représenter en JavaScript.
Number.MAX_SAFE_INTEGERLa valeur entière maximale qu'on peut représenter en JavaScript (253 - 1).
Number.MAX_VALUELa valeur numérique maximale qu'on peut représenter en JavaScript.
Number.MIN_SAFE_INTEGERLa valeur entière minimale qu'on peut représenter en JavaScript (-(253 - 1)).
Number.MIN_VALUELa plus petite valeur positive qu'on peut représenter en JavaScript, c'est-à-dire le nombre le plus près de zéro qui n'est pas égal à zéro et qu'on peut représenter en JavaScript.
Number.NaNUne valeur spéciale pour représenter les valeurs non-numériques (NaN correspond à « NotaNumber » en anglais, qui signifie « n'est pas un nombre »).
Number.NEGATIVE_INFINITYUne valeur spéciale pour représenter l'infini négatif. Cette valeur est renvoyée quand on dépasse les valeurs représentables.
Number.POSITIVE_INFINITYUne valeur spéciale pour représenter l'infini (positif). Cette valeur est renvoyée quand on dépasse les valeurs représentables.
Méthodes statiques
Number.isFinite()Cette méthode permet de déterminer si la valeur numérique passée en argument est un nombre fini.
Number.isInteger()Cette méthode permet de déterminer si la valeur passée en argument est un entier.
Number.isNaN()Cette méthode permet de déterminer si la valeur passée en argument vaut
NaN.Number.isSafeInteger()Cette méthode permet de déterminer si la valeur passée en argument peut correctement être représentée comme un entier en JavaScript (savoir si elle est comprise entre -(253 - 1) et 253 - 1).
Number.parseFloat()Cette méthode correspond à la méthode
parseFloat()de l'objet global.Number.parseInt()Cette méthode correspond à la méthode
parseInt()de l'objet global.
Propriétés des instances
Ces propriétés sont définies surNumber.prototype et partagées par l'ensemble des instances deNumber.
Number.prototype.constructorLa fonction utilisée comme constructeur pour créer l'instance objet. Pour les instances
Number, la valeur initiale est le constructeurNumber().
Méthodes des instances
Number.prototype.toExponential()Retourne une chaîne représentant le nombre en notation exponentielle.
Number.prototype.toFixed()Retourne une chaîne représentant le nombre avec la notation en virgule fixe.
Number.prototype.toLocaleString()Retourne une chaîne avec une représentation du nombre tenant compte de la locale. Surcharge la méthode
Object.prototype.toLocaleString().Number.prototype.toPrecision()Retourne une chaîne représentant le nombre avec une précision donnée en notation en virgule fixe ou exponentielle.
Number.prototype.toString()Retourne une chaîne représentant le nombre dans une base numérique donnée. Surcharge la méthode
Object.prototype.toString().Number.prototype.valueOf()Retourne la valeur primitive de l'objet spécifié. Surcharge la méthode
Object.prototype.valueOf().
Exemples
>Utiliser l'objetNumber pour affecter des valeurs numériques à des variables
Dans l'exemple suivant, on utilise les propriétés de l'objetNumber pour affecter des valeurs à des variables numériques :
const plusGrandNombre = Number.MAX_VALUE;const plusPetitNombre = Number.MIN_VALUE;const infini = Number.POSITIVE_INFINITY;const infiniNégatif = Number.NEGATIVE_INFINITY;const nonNumérique = Number.NaN;Intervalle entier pourNumber
Dans l'exemple suivant, on illustre les valeurs numériques entières maximales et minimales qu'on peut représenter avec une valeurNumber :
const biggestInt = Number.MAX_SAFE_INTEGER; // (2**53 - 1) => 9007199254740991const smallestInt = Number.MIN_SAFE_INTEGER; // -(2**53 - 1) => -9007199254740991Lorsqu'on analyse et convertit des données JSON, les valeurs en dehors de cet intervalle peuvent entraîner des erreurs ou des corruptions de valeurs lors de leurs conversions.
Selon les objets qu'on souhaite représenter, on peut utiliserString dans certains cas pour représenter certaines valeurs.
Pour les plus grands nombres, on pourra utiliser le typeBigInt.
UtiliserNumber() pour convertir un objetDate
Dans l'exemple suivant, on convertit un objetDate en une valeur numérique grâce à la fonctionNumber() :
const d = new Date("1995-12-17T03:24:00");console.log(Number(d));Ceci affichera819199440000.
Convertir une chaîne de caractères représentant une valeur numérique, ounull en un nombre
Number("123"); // 123Number("123") === 123; // trueNumber("12.3"); // 12.3Number("12.00"); // 12Number("123e-1"); // 12.3Number(""); // 0Number(null); // 0Number("0x11"); // 17Number("0b11"); // 3Number("0o11"); // 9Number("toto"); // NaNNumber("100a"); // NaNNumber("-Infinity"); // -InfinitySpécifications
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-number-objects> |