DateTime::add
date_add
(PHP 5 >= 5.3.0, PHP 7, PHP 8)
DateTime::add -- date_add — 給一個 DateTime 對像增加一定量的天,月,年,小時,分鐘 以及秒。
參數
-
object
-
僅過程化風格:由 date_create() 返回的 DateTime 型別的對象。此函式會修改這個對象。
-
interval
-
DateInterval 對象。
返回值
返回被修改的 DateTime 對象, 或者在失敗時返回 false
.
範例
示例 #1 DateTime::add() 例程
物件導向風格
<?php
$date = new DateTime('2000-01-01');
$date->add(new DateInterval('P10D'));
echo $date->format('Y-m-d') . "\n";
?>
過程化風格
<?php
$date = date_create('2000-01-01');
date_add($date, date_interval_create_from_date_string('10 days'));
echo date_format($date, 'Y-m-d');
?>
以上例程會輸出:
2000-01-11
示例 #2 Further DateTime::add() 例程
<?php
$date = new DateTime('2000-01-01');
$date->add(new DateInterval('PT10H30S'));
echo $date->format('Y-m-d H:i:s') . "\n";
$date = new DateTime('2000-01-01');
$date->add(new DateInterval('P7Y5M4DT4H3M2S'));
echo $date->format('Y-m-d H:i:s') . "\n";
?>
以上例程會輸出:
2000-01-01 10:00:30 2007-06-05 04:03:02
示例 #3 當在 DateTime 上加月的時候要注意
<?php
$date = new DateTime('2000-12-31');
$interval = new DateInterval('P1M');
$date->add($interval);
echo $date->format('Y-m-d') . "\n";
$date->add($interval);
echo $date->format('Y-m-d') . "\n";
?>
以上例程會輸出:
2001-01-31 2001-03-03
註釋
在 PHP 5.2 的版本中, 也可以使用 DateTime::modify() 方法來替代本方法。
參見
- DateTime::sub() - 對一個 DateTime 對像減去一定量的 日、月、年、小時、分鐘和秒。
- DateTime::diff() - Returns the difference between two DateTime objects
- DateTime::modify() - 修改日期時間對象的值