0

0

Laravel中如何使用Carbon处理日期_Laravel日期时间格式化常用方法【详解】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-26 09:47:02

|

388人浏览过

|

来源于php中文网

原创

Carbon 在 Laravel 中开箱即用,Eloquent 自动将时间戳转为 Carbon 实例;format() 灵活但返回字符串,toDateString() 等语义方法更安全;时区操作需区分 local()/utc()/timezone();diffForHumans() 需判空且支持本地化。

laravel中如何使用carbon处理日期_laravel日期时间格式化常用方法【详解】

Carbon 在 Laravel 中不是“需要额外配置才能用”的工具,而是开箱即用的日期处理核心——所有 created_atupdated_at 字段默认就是 Carbon 实例,直接调用方法即可,不用 new Carbon() 也能格式化、加减、比较。

Carbon 实例从哪来?别手动 new

Laravel 的 Eloquent 模型自动将时间戳字段(created_atupdated_at 及你声明为 $dates$casts 的字段)转为 Carbon 对象。这意味着:

  • 直接访问 $user->created_at->format('Y-m-d') 是合法且推荐的
  • 手动写 new Carbon($date) 多数时候是冗余的,除非你要解析一个原始字符串(如表单提交"2024-03-15"
  • 若字段未被自动识别为日期(比如数据库类型是 TEXT 或未在模型中声明),Carbon 方法会报错:Call to a member function format() on string

format() 和 toDateString() 这类方法的区别

format() 是最灵活的格式化入口,但要注意它返回的是字符串,不是 Carbon 对象;而 toDateString()toTimeString()toISOString() 等是语义化快捷方法,内部也调用 format(),但更安全、不易拼错:

echo $post->created_at->format('Y年m月d日 H:i'); // 自定义中文格式
echo $post->created_at->toDateString();            // "2024-03-15"
echo $post->created_at->toISOString();              // "2024-03-15T08:30:00.000000Z"
  • format() 支持全部 PHP 日期格式字符(YmdHis 等),但大小写敏感,y(两位年)和 Y(四位年)容易写反
  • toFormattedDateString() 返回类似 "Mar 15, 2024",适合前端展示,但不带时间,别误用于需要时分秒的场景
  • 所有这些方法都不改变原 Carbon 实例,是“只读”操作

时区问题:local()、utc()、timezone() 到底怎么选?

Carbon 默认使用 PHP 配置的时区(通常是 UTC),但 Laravel 应用级时区由 config/app.php 中的 'timezone' => 'Asia/Shanghai' 控制。关键点:

  • $date->local() 把当前实例按应用时区解释(不转换值,只改时区标签),适合显示前统一口径
  • $date->utc() 强制转为 UTC 时间(值会变),适合存储或跨时区计算
  • $date->timezone('Europe/London') 显式切换时区(值同步换算),比 setTimezone() 更链式友好
  • 数据库中存 UTC 是最佳实践,但 created_at 写入时 Laravel 已自动转为 UTC(前提是 MySQL 的 time_zone 设置正确,否则可能双倍偏移)

diffForHumans() 为什么有时显示“1天前”,有时“23小时前”?

diffForHumans() 是面向用户的相对时间表达,它的输出取决于当前时间和目标时间的差值,以及是否启用「短格式」和「本地化」:

echo $post->created_at->diffForHumans();           // "2 hours ago"
echo $post->created_at->diffForHumans(true);        // "2h"(开启 short 属性)
echo $post->created_at->locale('zh')->diffForHumans(); // "2小时前"
  • 它不是简单减法,而是按“天、小时、分钟”分级判断:小于 45 秒 → “just now”,45–90 秒 → “1 minute ago”,以此类推
  • 如果模型字段本身是空值(null),调用该方法会抛出 Call to a member function diffForHumans() on null,务必先判空:$post->created_at?->diffForHumans()(PHP 8.0+ 空安全操作符)
  • 在 Blade 中可全局设置 locale:Carbon::setLocale(config('app.locale'));,放在 AppServiceProvider::boot()

真正容易被忽略的是:Carbon 的静态方法(如 Carbon::now()Carbon::parse())返回的实例,默认时区是系统时区,不一定等于 Laravel 的 app.timezone。如果业务强依赖统一时区,建议封装一个辅助函数或在基模型中提供 freshNow() 方法,而不是散落各处写 Carbon::now()->tz('Asia/Shanghai')

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2900

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1734

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1567

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

1120

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1546

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1277

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1669

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1310

2023.11.13

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

31

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.9万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 811人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号