Classe DateTimeImmutable
La classe DateTimeImmutable est l'analogue immuable de DateTime. Elle crée un nouvel objet à chaque modification, ce qui le rend plus prévisible et sûr à utiliser.
Moment actuel
Créons un objet DateTimeImmutable
avec la date et l'heure actuelles :
<?php
$date = new DateTimeImmutable();
?>
Date spécifique
Créons un objet DateTimeImmutable avec une date spécifiée :
<?php
$date = new DateTimeImmutable('2025-12-31');
?>
Date et heure spécifiques
Créons un objet DateTimeImmutable
avec une date et une heure spécifiées :
<?php
$date = new DateTimeImmutable('2025-12-31 12:59:59');
?>
Formatage de la sortie
La date créée peut être affichée dans un format donné
en utilisant la méthode format. Faisons
cela pour le moment actuel :
<?php
$date = new DateTimeImmutable();
echo $date->format('Y-m-d H:i:s');
?>
Résultat (changera en fonction du moment d'exécution) :
'2025-11-15 14:25:00'
Formatage d'une date spécifique
Formatons une date spécifique :
<?php
$date = new DateTimeImmutable('2025-12-31');
echo $date->format('d.m.Y');
?>
Résultat de l'exécution du code :
'31.12.2025'
Ajout d'un intervalle
L'ajout d'un intervalle à une date
se fait via la méthode add :
<?php
$date = new DateTimeImmutable('2025-05-15');
$interval = new DateInterval('P10D'); // 10 jours
$newDate = $date->add($interval);
echo $newDate->format('Y-m-d');
?>
Résultat de l'exécution du code :
'2025-05-25'
Soustraction d'un intervalle
La soustraction d'un intervalle d'une date
se fait via la méthode sub :
<?php
$date = new DateTimeImmutable('2025-05-15');
$interval = new DateInterval('P1M2D'); // 1 mois et 2 jours
$newDate = $date->sub($interval);
echo $newDate->format('Y-m-d');
?>
Résultat de l'exécution du code :
'2025-04-13'
Définition d'une nouvelle date
On peut définir une nouvelle date pour
l'objet DateTimeImmutable. Cela se fait
via la méthode setDate :
<?php
$date = new DateTimeImmutable();
$newDate = $date->setDate(2024, 12, 31);
echo $newDate->format('Y-m-d');
?>
Résultat de l'exécution du code :
'2024-12-31'
Définition de l'heure
On peut définir une nouvelle heure pour
l'objet DateTimeImmutable. Cela se fait
via la méthode setTime :
<?php
$date = new DateTimeImmutable();
$newDate = $date->setTime(15, 30, 0);
echo $newDate->format('H:i:s');
?>
Résultat de l'exécution du code :
'15:30:00'
Comparaison de dates
On peut comparer des objets avec des dates :
<?php
$date1 = new DateTimeImmutable('2025-01-01');
$date2 = new DateTimeImmutable('2025-02-01');
if ($date1 < $date2) {
echo '+++';
} else {
echo '---';
}
?>
Création d'un objet avec un fuseau horaire
Lors de la création d'un objet DateTimeImmutable
on peut spécifier un fuseau horaire :
<?php
$timeZone = new DateTimeZone('Europe/Moscow');
$date = new DateTimeImmutable('2025-12-31 23:59:59', $timeZone);
echo $date->format('Y-m-d H:i:s e');
?>
Résultat de l'exécution du code :
'2025-12-31 23:59:59 Europe/Moscow'
Voir aussi
-
classe
DateInterval,
qui définit un intervalle de temps -
classe
DateTimeZone,
qui définit un fuseau horaire