Klasa DateTimeImmutable
Klasa DateTimeImmutable jest niemodyfikowalnym odpowiednikiem DateTime. Tworzy nowy obiekt przy każdej modyfikacji, co czyni go bardziej przewidywalnym i bezpiecznym w użyciu.
Bieżący moment czasu
Stwórzmy obiekt DateTimeImmutable
z bieżącą datą i czasem:
<?php
$date = new DateTimeImmutable();
?>
Konkretna data
Stwórzmy obiekt DateTimeImmutable z określoną datą:
<?php
$date = new DateTimeImmutable('2025-12-31');
?>
Konkretna data i czas
Stwórzmy obiekt DateTimeImmutable
z określoną datą i czasem:
<?php
$date = new DateTimeImmutable('2025-12-31 12:59:59');
?>
Formatowanie wyjścia
Utworzoną datę można wypisać w zadanym formacie
za pomocą metody format. Zróbmy
to dla bieżącego momentu czasu:
<?php
$date = new DateTimeImmutable();
echo $date->format('Y-m-d H:i:s');
?>
Wynik (będzie się zmieniać w zależności od momentu wykonania):
'2025-11-15 14:25:00'
Formatowanie określonej daty
Sformatujmy określoną datę:
<?php
$date = new DateTimeImmutable('2025-12-31');
echo $date->format('d.m.Y');
?>
Wynik wykonania kodu:
'31.12.2025'
Dodawanie przedziału czasu
Dodawanie przedziału czasu do daty
realizowane jest przez metodę add:
<?php
$date = new DateTimeImmutable('2025-05-15');
$interval = new DateInterval('P10D'); // 10 dni
$newDate = $date->add($interval);
echo $newDate->format('Y-m-d');
?>
Wynik wykonania kodu:
'2025-05-25'
Odejmowanie przedziału czasu
Odejmowanie przedziału czasu od daty
realizowane jest przez metodę sub:
<?php
$date = new DateTimeImmutable('2025-05-15');
$interval = new DateInterval('P1M2D'); // 1 miesiąc i 2 dni
$newDate = $date->sub($interval);
echo $newDate->format('Y-m-d');
?>
Wynik wykonania kodu:
'2025-04-13'
Ustawienie nowej daty
Można ustawić nową datę dla
obiektu DateTimeImmutable. Robi się to
za pomocą metody setDate:
<?php
$date = new DateTimeImmutable();
$newDate = $date->setDate(2024, 12, 31);
echo $newDate->format('Y-m-d');
?>
Wynik wykonania kodu:
'2024-12-31'
Ustawienie czasu
Można ustawić nowy czas dla
obiektu DateTimeImmutable. Robi się to
za pomocą metody setTime:
<?php
$date = new DateTimeImmutable();
$newDate = $date->setTime(15, 30, 0);
echo $newDate->format('H:i:s');
?>
Wynik wykonania kodu:
'15:30:00'
Porównywanie dat
Można porównywać obiekty z datami:
<?php
$date1 = new DateTimeImmutable('2025-01-01');
$date2 = new DateTimeImmutable('2025-02-01');
if ($date1 < $date2) {
echo '+++';
} else {
echo '---';
}
?>
Tworzenie obiektu ze strefą czasową
Przy tworzeniu obiektu DateTimeImmutable
można określić strefę czasową:
<?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');
?>
Wynik wykonania kodu:
'2025-12-31 23:59:59 Europe/Moscow'
Zobacz też
-
klasa
DateInterval,
który określa przedział czasu -
klasa
DateTimeZone,
który określa strefę czasową