Třída DateTimeImmutable
Třída DateTimeImmutable je neměnným protějškem třídy DateTime. Vytváří nový objekt při jakékoli modifikaci, což ji činí předvídatelnější a bezpečnější pro práci.
Aktuální časový okamžik
Vytvořme objekt DateTimeImmutable
s aktuálním datem a časem:
<?php
$date = new DateTimeImmutable();
?>
Konkrétní datum
Vytvořme objekt DateTimeImmutable se zadaným datem:
<?php
$date = new DateTimeImmutable('2025-12-31');
?>
Konkrétní datum a čas
Vytvořme objekt DateTimeImmutable
se zadaným datem a časem:
<?php
$date = new DateTimeImmutable('2025-12-31 12:59:59');
?>
Formátování výstupu
Vytvořené datum lze vypsat v zadaném formátu
pomocí metody format. Udělejme to
pro aktuální časový okamžik:
<?php
$date = new DateTimeImmutable();
echo $date->format('Y-m-d H:i:s');
?>
Výsledek (bude se měnit v závislosti na okamžiku provedení):
'2025-11-15 14:25:00'
Formátování zadaného data
Naformátujme zadané datum:
<?php
$date = new DateTimeImmutable('2025-12-31');
echo $date->format('d.m.Y');
?>
Výsledek provedení kódu:
'31.12.2025'
Přidání intervalu
Přidání intervalu k datu
se provádí pomocí metody add:
<?php
$date = new DateTimeImmutable('2025-05-15');
$interval = new DateInterval('P10D'); // 10 dnů
$newDate = $date->add($interval);
echo $newDate->format('Y-m-d');
?>
Výsledek provedení kódu:
'2025-05-25'
Odečtení intervalu
Odečtení intervalu od data
se provádí pomocí metody sub:
<?php
$date = new DateTimeImmutable('2025-05-15');
$interval = new DateInterval('P1M2D'); // 1 měsíc a 2 dny
$newDate = $date->sub($interval);
echo $newDate->format('Y-m-d');
?>
Výsledek provedení kódu:
'2025-04-13'
Nastavení nového data
Objektu DateTimeImmutable lze nastavit nové datum. To se provádí
pomocí metody setDate:
<?php
$date = new DateTimeImmutable();
$newDate = $date->setDate(2024, 12, 31);
echo $newDate->format('Y-m-d');
?>
Výsledek provedení kódu:
'2024-12-31'
Nastavení času
Objektu DateTimeImmutable lze nastavit nový čas. To se provádí
pomocí metody setTime:
<?php
$date = new DateTimeImmutable();
$newDate = $date->setTime(15, 30, 0);
echo $newDate->format('H:i:s');
?>
Výsledek provedení kódu:
'15:30:00'
Porovnávání dat
Lze porovnávat objekty s daty:
<?php
$date1 = new DateTimeImmutable('2025-01-01');
$date2 = new DateTimeImmutable('2025-02-01');
if ($date1 < $date2) {
echo '+++';
} else {
echo '---';
}
?>
Vytvoření objektu s časovým pásmem
Při vytváření objektu DateTimeImmutable
lze zadat časové pásmo:
<?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');
?>
Výsledek provedení kódu:
'2025-12-31 23:59:59 Europe/Moscow'
Viz také
-
třída
DateInterval,
která zadává časový interval -
třída
DateTimeZone,
která zadává časové pásmo