Be warned, DateTime::setDate() does not check for invalid input.
Illustration:
<?php
$dt = new DateTime();
$dt->setDate(2012, 11, 31); // returns DateTime object and not false although this date does not exist
echo $dt->format('Y-m-d'); // output: 2012-12-01
?>
No error was generated on entering a non existing date, php silently changed it.
DateTime::setDate
date_date_set
(PHP 5 >= 5.2.0)
DateTime::setDate -- date_date_set — Sets the date
Descrizione
Stile orientato agli oggetti
Stile procedurale
Resets the current date of the DateTime object to a different date.
Elenco dei parametri
-
oggetto -
Solo per lo stile procedurale: Un oggetto DateTime restituito da date_create(). La funzione modifica questo oggetto.
-
year -
Year of the date.
-
month -
Month of the date.
-
day -
Day of the date.
Valori restituiti
Restituisce l'oggetto DateTime per il metodo chaining o FALSE in caso di fallimento.
Log delle modifiche
| Versione | Descrizione |
|---|---|
| 5.3.0 | Modificato il
valore di ritorno in caso di successo da NULL a DateTime. |
Esempi
Example #1 DateTime::setDate() example
Stile orientato agli oggetti
<?php
$date = new DateTime();
$date->setDate(2001, 2, 3);
echo $date->format('Y-m-d');
?>
Stile procedurale
<?php
$date = date_create();
date_date_set($date, 2001, 2, 3);
echo date_format($date, 'Y-m-d');
?>
I precedenti esempi visualizzeranno:
2001-02-03
Example #2 Values exceeding ranges are added to their parent values
<?php
$date = new DateTime();
$date->setDate(2001, 2, 28);
echo $date->format('Y-m-d') . "\n";
$date->setDate(2001, 2, 29);
echo $date->format('Y-m-d') . "\n";
$date->setDate(2001, 14, 3);
echo $date->format('Y-m-d') . "\n";
?>
Il precedente esempio visualizzerĂ :
2001-02-28 2001-03-01 2002-02-03
Vedere anche:
- DateTime::setISODate() - Sets the ISO date
- DateTime::setTime() - Sets the time
remy215 at laposte dot net ¶
1 year ago
