在咱們過去的Laravel項目中,常常須要用到time_ago這樣的字段,並將其轉換爲咱們熟悉的本地語言,能夠實現的方式有不少,好比編寫一個time_ago的輔助函數將其轉換成本地,或採用carbon的diffForHumans函數而後替換成本地語言來實現.laravel
過去咱們編寫過的代碼像這樣:
這樣
json
可是咱們須要將其替換成中文、繁體中文、日本或是韓文時,咱們就須要編寫多個相似的方法如:composer
time_ago_CN //簡體中文 time_ago_HK //繁體中文 time_ago_JP //日文 time_ago_KO //韓文
當項目變得國際化,或者須要支持更多語言時,就顯得不太方便.可是最近翻閱carbon的官方文檔時,發現carbon是支持多語言的,也就是上面的事情,carbon都實現過了...(這爲咱們的技術債又添上了一筆)函數
若是咱們想支持中文的話,咱們能夠爲模型上添加以上方法ui
public function createdAt($locale = 'zh') { Carbon::setLocale($locale); return $this->created_at->diffForHumans(); }
而後調用方式以下:this
//中文 $user->createdAt(); //9個月前 //簡繁體 $user->createdAt('zh_HK'); //9個月前 //日文 $user->createdAt('ja_JP'); //9ヶ月前
若是你想讓他變得更通用化,建議封裝成輔助函數spa
function time_ago($time, $locale = 'zh') { $time = $time instanceof Carbon ? $time : Carbon::parse($time); Carbon::setLocale($locale); return $time->diffForHumans(); }
carbon語言支持:https://carbon.nesbot.com/contribute/translate/code
carbon2.0默認在laravel5.8開始支持,若是是低於該版本的話,能夠經過如下方式來使用carbon2.0,如laravel5.6blog
在composer.json中添加如下選項rem
{ "require": { "nesbot/carbon": "2.24.0 as 1.39.0", "kylekatarnls/laravel-carbon-2": "^1.0.0" } }
而後執行composer update來更新咱們的依賴項
composer update
最後送上carbon官方文檔地址:https://carbon.nesbot.com/