Класс 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
,
который задает часовой пояс