日期及时间处理包 Carbon 在 Laravel 中的简单使用

在编写 PHP 应用时经常需要处理日期和时间,这篇文章带你了解一下 Carbon – 继承自 PHP DateTime 类的 API 扩展,它使得处理日期和时间更加简单。Laravel 中默认使用的时间处理类就是 Carbon。

1 安装

通过 Composer 来安装 Carbon:

c5f15a1abbd34f8427f5b73f369206aa29e.jpg

PS:由于 Laravel 项目已默认安装了此包,所以不需要再次执行上面的命令。

2 使用

你需要通过命名空间导入 Carbon 来使用,而不需每次都提供完整的名称。

04ae4041e485b83876a364bb26f675dced2.jpg

2.1 获取当前时间

可以同now() 方法获取当前的日期和时间。如果你不指定参数,它会使用 PHP 配置中的时区:

2e7ade87c7e81aef782737a623fee1be7f7.jpg

如果你想使用一个不同的时区,你需要传递一个有效的时区作为参数:
now()外,还提供了today()tomorrow()yesterday()等静态函数,不过,它们的时间都是 00:00:00

153f5df0753647ba08ce368953c81c8f1b9.jpg

以上输出结果其实是一个 Carbon 类型的日期时间对象:

8d36ae59a2d6b5ebe4182a40952747e189e.jpg

要想获取字符串类型的日期,可以使用下面的代码:

90113b50feed303d064a0582e0ffe910a44.jpg

2.2 日期类型转为字符串

如上所述,默认情况下,Carbon 的方法返回的为一个日期时间对象。虽然它是一个对象,但是你却可以直接使用 echo 输出结果,因为有 __toString魔术方法。但是如果你想把它转为字符串,可以使用 toDateStringtoDateTimeString方法:

dfaa7e4a9dfe48146313e94e5e300559282.jpg

2.3 日期解析

你还可以使用 parse方法解析任何顺序和类型的日期(结果为 Carbon 类型的日期时间对象):

2532dff0d5119118ae6eeda8d46979eb0b7.jpg

2.4 构造日期

你还可以使用单独的年月日来构造日期:

834f05477b065f2c28c289262c2e8ed7756.jpg

此外,还可以传递一个有效的时区作为最后一个参数。

2.5 日期操作

日期操作可以通过 add(增加)或 sub(减去)跟上要增加或减去的单位来完成。例如,你想给一个日期增加指定的天数,你可以使用 addDays方法。此外还提供了一个modify方法,参数格式为 +- 跟上值及单位。所以,如果你想给当前日期增加一年,你可以传递+1 year

a9aa5942d9474222adc0e823d38749669db.jpg

2.6 日期比较

Carbon中你可以使用下面的方法来比较日期:

  • min –返回最小日期。
  • max – 返回最大日期。
  • eq – 判断两个日期是否相等。
  • gt – 判断第一个日期是否比第二个日期大。
  • lt – 判断第一个日期是否比第二个日期小。
  • gte – 判断第一个日期是否大于等于第二个日期。
  • lte – 判断第一个日期是否小于等于第二个日期。

aac7604de0feac84967a23abb5c445ad616.jpg

要判断一个日期是否介于两个日期之间,可以使用 between() 方法,第三个可选参数指定比较是否可以相等,默认为true

e8bad91082d68d691e79604baaa1c15b7ac.jpg

此外还提供了一些辅助方法,你可以从它们的名字中明白其含义:

9cb8eafe724758479f3cb0279cfc47695a7.jpg

2.7 diffForHumans

“一个月前”比“30 天前”更便于阅读,很多日期库都提供了这个常见的功能,日期被解析后,有下面四种可能性:

  • 当比较的时间超过当前默认时间
    • 1天前
    • 5月前
  • 当用将来的时间与当前默认时间比较
    • 1小时距现在
    • 5月距现在
  • 当比较的值超过另一个值
    • 1小时前
    • 5月前
  • 当比较的值在另一个值之后
    • 1小时后
    • 5月后

你可以把第二个参数设置为 true 来删除“前”、“距现在”等修饰语:diffForHumans(Carbon $other, true)

c6cb0ea8f37f129a74d7d9a2a75c3474dc7.jpg

2.8 本地化

翻译成中文,参考上一篇文章

转载于:https://my.oschina.net/guozhouyuan/blog/1941359

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值