前言
我們大家在編寫 PHP 應(yīng)用時經(jīng)常需要處理日期和時間,這篇文章帶你了解一下 Carbon ? 繼承自 PHP DateTime 類的 API 擴(kuò)展,它使得處理日期和時間更加簡單。
Laravel 中默認(rèn)使用的時間處理類就是 Carbon。
<?php namespace Carbon; class Carbon extends DateTime { // code here }
你可以在 Carbon 命名空間的 Carbon 類中看到上面聲明的代碼片段。
安裝
可以通過 Composer 來安裝 Carbon:
composer require nesbot/carbon
PS:由于 Laravel 項(xiàng)目已默認(rèn)安裝了此包,所以不需要再次執(zhí)行上面的命令。
使用
你需要通過命名空間導(dǎo)入 Carbon 來使用,而不需每次都提供完整的名稱。
use CarbonCarbon;
獲取當(dāng)前時間
可以同 now() 方法獲取當(dāng)前的日期和時間。如果你不指定參數(shù),它會使用 PHP 配置中的時區(qū):
<?php echo Carbon::now(); //2016-10-14 20:21:20 ?>
如果你想使用一個不同的時區(qū),你需要傳遞一個有效的時區(qū)作為參數(shù):
// 直接使用字符串 echo Carbon::now('Europe/London'); //2016-10-14 20:21:20 // 或者 echo Carbon::now(new DateTimeZone('Europe/London'));
除 now() 外,還提供了 today() 、tomorrow() 、yesterday() 等靜態(tài)函數(shù),不過,它們的時間都是 00:00:00 :
echo Carbon::now(); // 2016-10-14 15:18:34 echo Carbon::today(); // 2016-10-14 00:00:00 echo Carbon::tomorrow('Europe/London'); // 2016-10-14 00:00:00 echo Carbon::yesterday(); // 2016-10-14 00:00:00
以上輸出結(jié)果其實(shí)是一個 Carbon 類型的日期時間對象:
Carbon {#179 ? +"date": "2016-06-14 00:00:00.000000" +"timezone_type": 3 +"timezone": "UTC" }
要想獲取字符串類型的日期,可以使用下面的代碼:
echo Carbon::today()->toDateTimeString(); echo Carbon::yesterday()->toDateTimeString(); echo Carbon::tomorrow()->toDateTimeString();
日期類型轉(zhuǎn)為字符串
如上所述,默認(rèn)情況下,Carbon 的方法返回的為一個日期時間對象。雖然它是一個對象,但是你卻可以直接使用 echo 輸出結(jié)果,因?yàn)橛?__toString 魔術(shù)方法。但是如果你想把它轉(zhuǎn)為字符串,可以使用 toDateString 或 toDateTimeString 方法:
echo Carbon::now()->toDateString(); //2016-10-14 echo Carbon::now()->toDateTimeString(); //2016-10-14 20:22:50
日期解析
你還可以使用 parse 方法解析任何順序和類型的日期(結(jié)果為 Carbon 類型的日期時間對象):
echo Carbon::parse('2016-10-15')->toDateTimeString(); //2016-10-15 00:00:00 echo Carbon::parse('2016-10-15')->toDateTimeString(); //2016-10-15 00:00:00 echo Carbon::parse('2016-10-15 00:10:25')->toDateTimeString(); //2016-10-15 00:10:25 echo Carbon::parse('today')->toDateTimeString(); //2016-10-15 00:00:00 echo Carbon::parse('yesterday')->toDateTimeString(); //2016-10-14 00:00:00 echo Carbon::parse('tomorrow')->toDateTimeString(); //2016-10-16 00:00:00 echo Carbon::parse('2 days ago')->toDateTimeString(); //2016-10-13 20:49:53 echo Carbon::parse('+3 days')->toDateTimeString(); //2016-10-18 20:49:53 echo Carbon::parse('+2 weeks')->toDateTimeString(); //2016-10-29 20:49:53 echo Carbon::parse('+4 months')->toDateTimeString(); //2017-02-15 20:49:53 echo Carbon::parse('-1 year')->toDateTimeString(); //2015-10-15 20:49:53 echo Carbon::parse('next wednesday')->toDateTimeString(); //2016-10-19 00:00:00 echo Carbon::parse('last friday')->toDateTimeString(); //2016-10-14 00:00:00
構(gòu)造日期
你還可以使用單獨(dú)的年月日來構(gòu)造日期:
$year = '2015'; $month = '04'; $day = '12'; echo Carbon::createFromDate($year, $month, $day); //2015-04-12 20:55:59 $hour = '02'; $minute = '15': $second = '30'; echo Carbon::create($year, $month, $day, $hour, $minute, $second); //2015-04-12 02:15:30 echo Carbon::createFromDate(null, 12, 25); // 年默認(rèn)為當(dāng)前年份
此外,還可以傳遞一個有效的時區(qū)作為最后一個參數(shù)。
日期操作
日期操作可以通過 add (增加)或 sub (減去)跟上要增加或減去的單位來完成。例如,你想給一個日期增加指定的天數(shù),你可以使用 addDays 方法。此外還提供了一個 modify 方法,參數(shù)格式為 + 或 - 跟上值及單位。所以,如果你想給當(dāng)前日期增加一年,你可以傳遞 +1 year:
echo Carbon::now()->addDays(25); //2016-11-09 14:00:01 echo Carbon::now()->addWeeks(3); //2016-11-05 14:00:01 echo Carbon::now()->addHours(25); //2016-10-16 15:00:01 echo Carbon::now()->subHours(2); //2016-10-15 12:00:01 echo Carbon::now()->addHours(2)->addMinutes(12); //2016-10-15 16:12:01 echo Carbon::now()->modify('+15 days'); //2016-10-30 14:00:01 echo Carbon::now()->modify('-2 days'); //2016-10-13 14:00:01
日期比較
在 Carbon 中你可以使用下面的方法來比較日期:
min ?返回最小日期。 max ? 返回最大日期。 eq ? 判斷兩個日期是否相等。 gt ? 判斷第一個日期是否比第二個日期大。 lt ? 判斷第一個日期是否比第二個日期小。 gte ? 判斷第一個日期是否大于等于第二個日期。 lte ? 判斷第一個日期是否小于等于第二個日期。echo Carbon::now()->tzName; // America/Toronto $first = Carbon::create(2012, 9, 5, 23, 26, 11); $second = Carbon::create(2012, 9, 5, 20, 26, 11, 'America/Vancouver'); echo $first->toDateTimeString(); // 2012-09-05 23:26:11 echo $first->tzName; // America/Toronto echo $second->toDateTimeString(); // 2012-09-05 20:26:11 echo $second->tzName; // America/Vancouver var_dump($first->eq($second)); // bool(true) var_dump($first->ne($second)); // bool(false) var_dump($first->gt($second)); // bool(false) var_dump($first->gte($second)); // bool(true) var_dump($first->lt($second)); // bool(false) var_dump($first->lte($second)); // bool(true) $first->setDateTime(2012, 1, 1, 0, 0, 0); $second->setDateTime(2012, 1, 1, 0, 0, 0); // Remember tz is 'America/Vancouver' var_dump($first->eq($second)); // bool(false) var_dump($first->ne($second)); // bool(true) var_dump($first->gt($second)); // bool(false) var_dump($first->gte($second)); // bool(false) var_dump($first->lt($second)); // bool(true) var_dump($first->lte($second)); // bool(true)
要判斷一個日期是否介于兩個日期之間,可以使用 between() 方法,第三個可選參數(shù)指定比較是否可以相等,默認(rèn)為 true:
$first = Carbon::create(2012, 9, 5, 1); $second = Carbon::create(2012, 9, 5, 5); var_dump(Carbon::create(2012, 9, 5, 3)->between($first, $second)); // bool(true) var_dump(Carbon::create(2012, 9, 5, 5)->between($first, $second)); // bool(true) var_dump(Carbon::create(2012, 9, 5, 5)->between($first, $second, false)); // bool(false)
此外還提供了一些輔助方法,你可以從它們的名字中明白其含義:
$dt = Carbon::now(); $dt->isWeekday(); $dt->isWeekend(); $dt->isYesterday(); $dt->isToday(); $dt->isTomorrow(); $dt->isFuture(); $dt->isPast(); $dt->isLeapYear(); $dt->isSameDay(Carbon::now()); $born = Carbon::createFromDate(1987, 4, 23); $noCake = Carbon::createFromDate(2014, 9, 26); $yesCake = Carbon::createFromDate(2014, 4, 23); $overTheHill = Carbon::now()->subYears(50); var_dump($born->isBirthday($noCake)); // bool(false) var_dump($born->isBirthday($yesCake)); // bool(true) var_dump($overTheHill->isBirthday()); // bool(true) -> default compare it to today!
diffForHumans
“一個月前”比“30 天前”更便于閱讀,很多日期庫都提供了這個常見的功能,日期被解析后,有下面四種可能性:
1、當(dāng)比較的時間超過當(dāng)前默認(rèn)時間
2、當(dāng)用將來的時間與當(dāng)前默認(rèn)時間比較
3、當(dāng)比較的值超過另一個值
4、當(dāng)比較的值在另一個值之后
你可以把第二個參數(shù)設(shè)置為 true 來刪除“前”、“距現(xiàn)在”等修飾語:diffForHumans(Carbon $other, true) 。
echo Carbon::now()->subDays(5)->diffForHumans(); // 5天前 echo Carbon::now()->diffForHumans(Carbon::now()->subYear()); // 1年后 $dt = Carbon::createFromDate(2011, 8, 1); echo $dt->diffForHumans($dt->copy()->addMonth()); // 1月前 echo $dt->diffForHumans($dt->copy()->subMonth()); // 11月后 echo Carbon::now()->addSeconds(5)->diffForHumans(); // 5秒距現(xiàn)在 echo Carbon::now()->subDays(24)->diffForHumans(); // 3周前 echo Carbon::now()->subDays(24)->diffForHumans(null, true); // 3周
本地化
可以在 app/Providers/AppServiceProvider.php 的 boot() 方法中添加下面的代碼來設(shè)置全局本地化:
public function boot() { CarbonCarbon::setLocale('zh'); }
設(shè)置好之后,在輸出時間的地方調(diào)用:
$article->created_at->diffForHumans();
類似的格式即可。
更多 Carbon 操作,可查看文檔。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對綠夏網(wǎng)的支持。