Клас DateTimeImmutable
Класът DateTimeImmutable е неизменяем аналог на DateTime. Той създава нов обект при всяка модификация, което го прави по-предсказуем и безопасен за работа.
Текущ момент от време
Нека създадем обект DateTimeImmutable
с текуща дата и време:
<?php
$date = new DateTimeImmutable();
?>
Конкретна дата
Нека създадем обект DateTimeImmutable с указана дата:
<?php
$date = new DateTimeImmutable('2025-12-31');
?>
Конкретна дата и време
Нека създадем обект DateTimeImmutable
с указана дата и време:
<?php
$date = new DateTimeImmutable('2025-12-31 12:59:59');
?>
Форматиране на изхода
Създадената дата може да бъде изведена в зададен формат
с помощта на метода format. Нека направим
това за текущия момент от време:
<?php
$date = new DateTimeImmutable();
echo $date->format('Y-m-d H:i:s');
?>
Резултат (ще се променя в зависимост от момента на изпълнение):
'2025-11-15 14:25:00'
Форматиране на зададена дата
Нека форматираме зададена дата:
<?php
$date = new DateTimeImmutable('2025-12-31');
echo $date->format('d.m.Y');
?>
Резултат от изпълнението на кода:
'31.12.2025'
Добавяне на интервал
Добавяне на интервал към дата
се осъществява чрез метода add:
<?php
$date = new DateTimeImmutable('2025-05-15');
$interval = new DateInterval('P10D'); // 10 дни
$newDate = $date->add($interval);
echo $newDate->format('Y-m-d');
?>
Резултат от изпълнението на кода:
'2025-05-25'
Изваждане на интервал
Изваждане на интервал от дата
се осъществява чрез метода sub:
<?php
$date = new DateTimeImmutable('2025-05-15');
$interval = new DateInterval('P1M2D'); // 1 месец и 2 дни
$newDate = $date->sub($interval);
echo $newDate->format('Y-m-d');
?>
Резултат от изпълнението на кода:
'2025-04-13'
Задаване на нова дата
Може да се зададе нова дата за
обекта DateTimeImmutable. Това се прави
чрез метода setDate:
<?php
$date = new DateTimeImmutable();
$newDate = $date->setDate(2024, 12, 31);
echo $newDate->format('Y-m-d');
?>
Резултат от изпълнението на кода:
'2024-12-31'
Задаване на време
Може да се зададе ново време за
обекта DateTimeImmutable. Това се прави
чрез метода setTime:
<?php
$date = new DateTimeImmutable();
$newDate = $date->setTime(15, 30, 0);
echo $newDate->format('H:i:s');
?>
Резултат от изпълнението на кода:
'15:30:00'
Сравняване на дати
Може да се сравняват обекти с дати:
<?php
$date1 = new DateTimeImmutable('2025-01-01');
$date2 = new DateTimeImmutable('2025-02-01');
if ($date1 < $date2) {
echo '+++';
} else {
echo '---';
}
?>
Създаване на обект с часова зона
При създаване на обект DateTimeImmutable
може да се укаже часова зона:
<?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');
?>
Резултат от изпълнението на кода:
'2025-12-31 23:59:59 Europe/Moscow'
Вижте също
-
клас
DateInterval,
който задава времеви интервал -
клас
DateTimeZone,
който задава часова зона