Date
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
Les objets JavaScript Date
représentent un instant donné sur l'axe du temps dans un format indépendant de la plateforme utilisée. Les objets Date
contiennent un nombre (Number
) qui représente le nombre de millisecondes écoulées depuis le premier janvier 1970 sur l'échelle UTC.
Note : TC39 travaille actuellement sur Temporal, une nouvelle API pour la gestion des dates, heures et données temporelles. Pour en savoir plus, consultez le blog d'Igalia et n'hésitez pas à répondre au sondage. Les retours concrets de développeurs web sont importants pour affiner cette API. Attention, elle n'est pas encore prête à être utilisée en production !
Description
L'epoch ECMAScript
D'un point de vue technique, une date JavaScript correspond au nombre de millisecondes écoulées depuis le premier janvier 1970, minuit UTC. Cette date et cette heure sont les mêmes que l'epoch UNIX, qui est l'instant de référence principalement utilisé pour manipuler les dates/heures dans les systèmes informatiques.
Note : Bien que les valeurs temporelles des objets dates soient relatives à UTC, certaines des méthodes simples pour obtenir les composantes d'une date/heure fonctionnent relativement au fuseau horaire du système.
On notera également que la représentation maximale d'un objet Date
n'est pas la même que le plus grand entier représentable en JavaScript (Number.MAX_SAFE_INTEGER
vaut 9,007,199,254,740,991). En effet, ECMA-262 définit un maximum de ±100 000 000 (cent millions) jours relatifs au premier janvier 1970 UTC (ce qui correspond au 20 avril 271 821 avant notre ètre d'une part et au 13 septembre 275 760 de notre ère) pouvant être représentés par un objet Date
standard (soit un intervalle de ±8 640 000 000 000 000 millisecondes).
Les formats de date et les conversions entre les fuseaux horaires
Il existe différentes méthodes pour obtenir une date sous différents formats ou effectuer une conversion entre différents fuseaux. On distingue notamment les fonctions qui manipulent les dates relativement au temps universal coordonné (UTC). Le temps local est celui utilisé par l'appareil de l'utilisateur.
Ainsi, on dispose de méthodes permettant d'obtenir ou de définir les différentes composantes d'une date selon le temps local (ex. getDay()
, setHours()
) et de méthodes équivalentes pour la manipulation en UTC (ex. getUTCDay()
et setUTCHours()
respectivement).
Constructeur
Date()
-
Cette fonction permet de créer un nouvel objet
Date
.
Méthodes statiques
Date.now()
-
Renvoie la valeur numérique correspondant au moment présent sous la forme du nombre de millisecondes écoulées depuis le premier janvier 1970 00:00:00 UTC (les secondes intercalaires (leap seconds) sont ignorées).
Date.parse()
-
Analyse la représentation textuelle d'une date et renvoie le nombre de millisecondes écoulées entre cette date et le premier janvier 1970, 00:00:00 UTC (les secondes intercalaires (leap seconds) sont ignorées).
Note : L'analyse de chaînes de caractères à l'aide de
Date.parse
est fortement déconseillée en raison des incohérences qui existent entre les navigateurs. Date.UTC()
-
Accepte les mêmes paramètres que la forme longue du constructeur (c'est-à-dire entre 2 et 7) et renvoie le nombre de millisecondes entre cette date et le premier janvier 1970, 00:00:00 UTC (les secondes intercalaires (leap seconds) sont ignorées).
Méthodes des instances
Date.prototype.getDate()
-
Renvoie le jour du mois (entre
1
et31
) pour la date donnée, selon le temps local. Date.prototype.getDay()
-
Renvoie le jour de la semaine (entre
0
et6
) pour la date donnée, selon le temps local. Date.prototype.getFullYear()
-
Renvoie l'année (sans chiffre implicite,
1999
sera renvoyé et pas99
par exemple) pour la date donnée, selon le temps local. Date.prototype.getHours()
-
Renvoie l'heure (entre
0
et23
) pour la date donnée, selon le temps local. Date.prototype.getMilliseconds()
-
Renvoie les millisecondes (entre
0
et999
) pour la date donnée, selon le temps local. Date.prototype.getMinutes()
-
Renvoie les minutes (entre
0
et59
) pour la date donnée, selon le temps local. Date.prototype.getMonth()
-
Renvoie le mois (entre
0
et11
) pour la date donnée, selon le temps local. Date.prototype.getSeconds()
-
Renvoie les secondes (entre
0
et59
) pour la date donnée, selon le temps local. Date.prototype.getTime()
-
Renvoie la valeur numérique de la date donnée, exprimée en nombre de millisecondes écoulées depuis le premier janvier 1970, 00:00:00 UTC (pour les temps antérieurs, ce sont des valeurs négatives qui seront renvoyées).
Date.prototype.getTimezoneOffset()
-
Renvoie le décalage horaire, exprimé en minutes, pour la locale courante.
Date.prototype.getUTCDate()
-
Renvoie le jour du mois (entre
1
et31
) pour la date donnée, selon le temps universel. Date.prototype.getUTCDay()
-
Renvoie le jour de la semaine (entre
0
et6
) pour la date donnée, selon le temps universel. Date.prototype.getUTCFullYear()
-
Renvoie l'année (sans chiffre implicite,
1999
sera renvoyé plutôt que99
) pour la date donnée, selon le temps universel. Date.prototype.getUTCHours()
-
Renvoie l'heure (entre
0
et23
) pour la date donnée, selon le temps universel. Date.prototype.getUTCMilliseconds()
-
Renvoie les millisecondes (entre
0
et999
) pour la date donnée, selon le temps universel. Date.prototype.getUTCMinutes()
-
Renvoie les minutes (entre
0
et59
) pour la date donnée, selon le temps universel. Date.prototype.getUTCMonth()
-
Renvoie le mois (entre
0
et11
) pour la date donnée, selon le temps universel. Date.prototype.getUTCSeconds()
-
Renvoie les secondes (entre
0
et59
) pour la date donnée, selon le temps universel. Date.prototype.getYear()
-
Renvoie l'année (généralement exprimée sur 2 ou 3 chiffres) pour la date donnée selon le temps local. On utilisera plutôt
getFullYear()
. Date.prototype.setDate()
-
Définit le jour du mois pour la date donnée, selon le temps local.
Date.prototype.setFullYear()
-
Définit l'année (sans chiffre implicite, on utilisera
1999
et pas99
) pour la date donnée, selon le temps local. Date.prototype.setHours()
-
Définit les heures pour la date donnée, selon le temps local.
Date.prototype.setMilliseconds()
-
Définit les millisecondes pour la date donnée, selon le temps local.
Date.prototype.setMinutes()
-
Définit les minutes pour la date donnée, selon le temps local.
Date.prototype.setMonth()
-
Définit le mois pour la date donnée, selon le temps local.
Date.prototype.setSeconds()
-
Définit les secondes pour la date donnée, selon le temps local.
Date.prototype.setTime()
-
Définit le nombre de millisecondes écoulées depuis le premier janvier 1970, 00:00:00 UTC et la date donnée. On utilisera des nombres négatifs pour les moments antérieurs à cette date.
Date.prototype.setUTCDate()
-
Définit le jour du mois pour la date donnée selon le temps universel.
Date.prototype.setUTCFullYear()
-
Définit l'année (exprimée sans chiffres implicites, ex.
1999
et pas99
) pour la date donnée selon le temps universel. Date.prototype.setUTCHours()
-
Définit l'heure pour la date donnée selon le temps universel.
Date.prototype.setUTCMilliseconds()
-
Définit les millisecondes pour la date donnée selon le temps universel.
Date.prototype.setUTCMinutes()
-
Définit les minutes pour la date donnée selon le temps universel.
Date.prototype.setUTCMonth()
-
Définit le mois pour la date donnée selon le temps universel.
Date.prototype.setUTCSeconds()
-
Définit les secondes pour la date donnée selon le temps universel.
Date.prototype.setYear()
-
Définit l'année (avec 2 à 3 chiffres) pour la date courante selon le temps local. On privilégiera la méthode
setFullYear()
à la place. Date.prototype.toDateString()
-
Renvoie la partie "date" (jour, mois, année) de l'objet
Date
en une chaîne de caractères compréhensible par un humain (anglophone) (ex.'Thu Apr 12 2018'
). Date.prototype.toISOString()
-
Convertit une date en une chaîne de caractères selon le format ISO 8601 Étendu.
Date.prototype.toJSON()
-
Renvoie une chaîne de caractères représentant l'objet
Date
avectoISOString()
. Cette méthode est utilisée parJSON.stringify()
. Date.prototype.toGMTString()
-
Renvoie une chaîne de caractères représentant l'objet
Date
d'après le fuseau GMT (UTC). On utilisera plutôttoUTCString()
. Date.prototype.toLocaleDateString()
-
Renvoie une chaîne de caractères représentant les jours / mois / années de la date courante avec une représentation propre à la locale courante (déduite des paramètres systèmes utilisés).
Date.prototype.toLocaleFormat()
-
Convertit la date courante en une chaîne de caractères avec un format décrit en paramètre via une chaîne de caractères.
Date.prototype.toLocaleString()
-
Renvoie une chaîne de caractères représentant la date sous le forme de la locale courante. Cette méthode surcharge la méthode
Object.prototype.toLocaleString()
. Date.prototype.toLocaleTimeString()
-
Renvoie une chaîne de caractères représentant les heures / minutes / secondes de la date courante avec une représentation propre à la locale courante (déduite des paramètres systèmes utilisés).
Date.prototype.toString()
-
Renvoie une chaîne de caractères représentant l'objet
Date
courant. Cette méthode surcharge la méthodeObject.prototype.toString()
. Date.prototype.toTimeString()
-
Renvoie l'heure (avec les minutes et les secondes) d'une date sous la forme d'une chaîne de caractères compréhensible par un humain.
Date.prototype.toUTCString()
-
Convertit une date en chaîne de caractère en utilisant le temps universel comme référentiel.
Date.prototype.valueOf()
-
Renvoie la valeur primitive d'un objet
Date
. Cette méthode surcharge la méthodeObject.prototype.valueOf()
.
Exemples
Différentes façons de créer un objet Date
Les exemples qui suivent illustrent différentes méthodes permettant de créer des dates JavaScript :
Note :
L'analyse de chaîne de caractères représentant des dates avec le constructeur Date
(ou Date.parse
qui est équivalent) est fortement déconseillée en raison des différences de comportement existant entre les navigateurs.
let aujourdhui = new Date();
let anniversaire = new Date("September 22, 2018 15:00:00");
let anniversaire = new Date("2018-09-22T15:00:00");
let anniversaire = new Date(2018, 8, 22); // the month is 0-indexed
let anniversaire = new Date(2018, 8, 22, 15, 0, 0);
Les années sur deux chiffres correspondent à la période 1900 – 1999
Afin de créer et de manipuler des dates sur les années 0
à 99
de notre ère, on doit utiliser les méthodes Date.prototype.setFullYear()
and Date.prototype.getFullYear()
.
let date = new Date(98, 1); // Sun Feb 01 1998 00:00:00 GMT+0000 (GMT)
// Méthode dépréciée, 98 correspond également ici à 1998
date.setYear(98); // Sun Feb 01 1998 00:00:00 GMT+0000 (GMT)
date.setFullYear(98); // Sat Feb 01 0098 00:00:00 GMT+0000 (BST)
Calculer le temps écoulé
Dans les exemples suivants, on illustre comment calculer le temps écoulé entre deux dates JavaScript en millisecondes.
En raison de durées différentes pour les jours (heure d'été / heure d'hiver), les mois et les années, il faudra faire attention et étudier le sujet avant d'exprimer des durées en unités supérieures à des heures / minutes / secondes.
// Utiliser des objets Date
let debut = Date.now();
// Ici, l'évènement dont on veut mesurer la durée :
faireQuelqueChosePendantLongtemps();
let fin = Date.now();
let duree = fin - debut; // La durée écoulée, en millisecondes
// En utilisant les méthodes natives
let debut = new Date();
// Ici, l'évènement dont on veut mesurer la durée :
faireQuelqueChosePendantLongtemps();
let fin = new Date();
let duree = fin.getTime() - debut.getTime(); // La durée écoulée, en millisecondes
// Pour tester le temps d'exécution d'une fonction
function afficheDureeEcoulee(fTest) {
let debut = Date.now(),
valRetour = fTest(),
fin = Date.now();
console.log(`Durée écoulée : ${String(fin - debut)} millisecondes`);
return valRetour;
}
let valeurDeRetour = afficheDureeEcoulee(maFonctionATester);
Note :
Pour les navigateurs qui prennent en charge l'API Web Performance, la méthode Performance.now()
peut fournir un outil de mesure des durées écoulées plus fiable et précis que Date.now()
.
Obtenir le nombre de secondes écoulées depuis l'epoch ECMAScript
let secondes = Math.floor(Date.now() / 1000);
Dans ce cas, on renvoie un entier et c'est pour ça qu'on utilise Math.floor()
. Par ailleurs, on n'utilise pas Math.round()
afin d'avoir le nombre de secondes effectivement écoulées.
Spécifications
Specification |
---|
ECMAScript Language Specification # sec-date-objects |
Compatibilité des navigateurs
BCD tables only load in the browser
Voir aussi
- Le constructeur
Date()