Php/docs/intlcalendar.roll

来自菜鸟教程
跳转至:导航、​搜索

IntlCalendar::roll

(PHP 5 >= 5.5.0, PHP 7, PECL >= 3.0.0a1)

IntlCalendar::rollAdd value to field without carrying into more significant fields


说明

面向对象风格

public IntlCalendar::roll ( int $field , mixed $amountOrUpOrDown ) : bool

过程化风格

intlcal_roll ( IntlCalendar $cal , int $field , mixed $amountOrUpOrDown ) : bool

Adds a (signed) amount to a field. The difference with respect to IntlCalendar::add() is that when the field value overflows, it does not carry into more significant fields.


参数

cal
The IntlCalendar resource.
field
One of the IntlCalendar date/time field constants. These are integer values between 0 and IntlCalendar::FIELD_COUNT.
amountOrUpOrDown
The (signed) amount to add to the field, true for rolling up (adding 1), or false for rolling down (subtracting 1).


返回值

Returns true on success or false on failure.


范例

Example #1 IntlCalendar::roll()

<?phpini_set('date.timezone', 'Europe/Lisbon');ini_set('intl.default_locale', 'pt_PT');$cal = new IntlGregorianCalendar(2013, 5 /* June */, 30);$cal->add(IntlCalendar::FIELD_DAY_OF_MONTH, 1);var_dump(IntlDateFormatter::formatObject($cal)); // "01/07/2013, 00:00:00"$cal->set(2013, 5 /* June */, 30);$cal->roll(IntlCalendar::FIELD_DAY_OF_MONTH, true); // roll up, same as rolling +1var_dump(IntlDateFormatter::formatObject($cal)); // "01/06/2013, 00:00:00"

以上例程会输出:


string(20) "01/07/2013, 00:00:00"
string(20) "01/06/2013, 00:00:00"

参见