Laravel通过事件与监听器实现解耦,先创建事件和监听器类,再在EventServiceProvider中注册映射关系,接着通过event()函数触发事件,监听器按序执行逻辑,支持队列异步处理,可选事件自动发现机制,提升代码可维护性。

Laravel 的事件和监听器系统提供了一种优雅的方式来解耦应用中的各种操作。你可以通过触发一个事件,让一个或多个监听器去响应它,而不需要把逻辑硬编码在一起。这种机制特别适合处理日志记录、发送邮件、通知等副任务。
在 Laravel 中,事件类通常放在 app/Events 目录下,监听器类放在 app/Listeners 目录下。你可以使用 Artisan 命令快速生成它们:
php artisan make:event OrderShipped
php artisan make:listener SendShipmentNotification --event=OrderShipped
上面命令会创建一个 OrderShipped 事件和一个监听器 SendShipmentNotification,并自动关联到该事件。
Laravel 使用 EventServiceProvider 来注册事件和监听器的映射关系。打开 app/Providers/EventServiceProvider.php 文件,在 $listen 数组中添加绑定:
'App\Events\OrderShipped' => [
'App\Listeners\SendShipmentNotification',
],
如果有多个监听器监听同一个事件,可以继续添加。每次修改后不需要手动刷新,Laravel 会在请求中自动加载(但在生产环境建议运行 php artisan event:cache 提升性能)。
使用 event() 辅助函数或 Event 门面来触发事件。例如在控制器中:
use App\Events\OrderShipped;
// ...
public function ship(Order $order)
{
event(new OrderShipped($order));
// 或者 Event::dispatch(new OrderShipped($order));
return response()->json(['message' => '订单已发货']);
}
只要事件被触发,所有注册的监听器就会按顺序执行。
监听器的 handle 方法接收事件实例作为参数。你可以在其中访问事件携带的数据:
public function handle(OrderShipped $event)
{
$order = $event->order;
// 发送通知或邮件
\Log::info("订单 {$order->id} 已发货,正在发送通知...");
}
如果监听器执行耗时操作(如发邮件),建议将其放入队列。只需让监听器实现 ShouldQueue 接口即可:
use Illuminate\Contracts\Queue\ShouldQueue;
class SendShipmentNotification implements ShouldQueue { }
这样 Laravel 会自动将该监听器任务推入队列异步处理,提升接口响应速度。
Laravel 支持自动发现事件和监听器,无需手动注册。只需要在 EventServiceProvider 中启用:
public function shouldDiscoverEvents()
{
return true;
}
然后确保事件和监听器在指定目录下,并使用正确的命名空间。Laravel 会自动扫描并建立映射。
基本上就这些。Laravel 的事件系统让代码更清晰、更易维护,尤其适合复杂业务中分离关注点。合理使用能显著提升项目结构质量。
以上就是Laravel的事件和监听器(Events & Listeners)怎么用的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号