日期及时间处理包 Carbon 在 Laravel 中的简单使用
在编写 PHP 应用时经常需要处理日期和时间,这篇文章带你了解一下 Carbon – 继承自 PHP DateTime 类的 API 扩展,它使得处理日期和时间更加简单。Laravel 中默认使用的时间处理类就是 Carbon。
1 安装
通过 Composer 来安装 Carbon:
PS:由于 Laravel 项目已默认安装了此包,所以不需要再次执行上面的命令。
2 使用
你需要通过命名空间导入 Carbon 来使用,而不需每次都提供完整的名称。
2.1 获取当前时间
可以同now()
方法获取当前的日期和时间。如果你不指定参数,它会使用 PHP 配置中的时区:
如果你想使用一个不同的时区,你需要传递一个有效的时区作为参数:
除 now()
外,还提供了today()
、tomorrow()
、yesterday()
等静态函数,不过,它们的时间都是 00:00:00
:
以上输出结果其实是一个 Carbon 类型的日期时间对象:
要想获取字符串类型的日期,可以使用下面的代码:
2.2 日期类型转为字符串
如上所述,默认情况下,Carbon 的方法返回的为一个日期时间对象。虽然它是一个对象,但是你却可以直接使用 echo 输出结果,因为有 __toString
魔术方法。但是如果你想把它转为字符串,可以使用 toDateString
或 toDateTimeString
方法:
2.3 日期解析
你还可以使用 parse
方法解析任何顺序和类型的日期(结果为 Carbon 类型的日期时间对象):
2.4 构造日期
你还可以使用单独的年月日来构造日期:
此外,还可以传递一个有效的时区作为最后一个参数。
2.5 日期操作
日期操作可以通过 add
(增加)或 sub
(减去)跟上要增加或减去的单位来完成。例如,你想给一个日期增加指定的天数,你可以使用 addDays
方法。此外还提供了一个modify
方法,参数格式为 +
或 -
跟上值及单位。所以,如果你想给当前日期增加一年,你可以传递+1 year
:
2.6 日期比较
在 Carbon
中你可以使用下面的方法来比较日期:
- min –返回最小日期。
- max – 返回最大日期。
- eq – 判断两个日期是否相等。
- gt – 判断第一个日期是否比第二个日期大。
- lt – 判断第一个日期是否比第二个日期小。
- gte – 判断第一个日期是否大于等于第二个日期。
- lte – 判断第一个日期是否小于等于第二个日期。
要判断一个日期是否介于两个日期之间,可以使用 between()
方法,第三个可选参数指定比较是否可以相等,默认为true
:
此外还提供了一些辅助方法,你可以从它们的名字中明白其含义:
2.7 diffForHumans
“一个月前”比“30 天前”更便于阅读,很多日期库都提供了这个常见的功能,日期被解析后,有下面四种可能性:
- 当比较的时间超过当前默认时间
- 1天前
- 5月前
- 当用将来的时间与当前默认时间比较
- 1小时距现在
- 5月距现在
- 当比较的值超过另一个值
- 1小时前
- 5月前
- 当比较的值在另一个值之后
- 1小时后
- 5月后
你可以把第二个参数设置为 true 来删除“前”、“距现在”等修饰语:diffForHumans(Carbon $other, true)
。
2.8 本地化
翻译成中文,参考上一篇文章