Laravel通过事件与监听器实现解耦,先创建事件类传递数据,再创建监听器处理逻辑,接着在EventServiceProvider中注册对应关系,最后通过event()触发事件,支持自动发现和队列异步执行。

Laravel 的事件系统提供了一种优雅的方式来解耦应用中的各种操作。通过事件和监听器机制,你可以定义某个动作发生时触发的“事件”,然后由一个或多个“监听器”来响应这个事件。这种模式非常适合处理日志记录、发送通知、更新缓存等场景。
事件类通常存放在 app/Events 目录下。你可以使用 Artisan 命令创建一个事件:
php artisan make:event OrderShipped执行后会生成 app/Events/OrderShipped.php 文件。你可以在构造函数中注入需要的数据:
class OrderShipped
{
public $order;
public function __construct(Order $order)
{
$this->order = $order;
}
}
监听器用于响应特定事件。使用以下命令创建监听器:
php artisan make:listener SendShippingNotification --event=OrderShipped这会在 app/Listeners 目录下创建监听器,并自动绑定到指定事件。
打开 SendShippingNotification.php,在 handle 方法中编写响应逻辑:
class SendShippingNotification
{
public function handle(OrderShipped $event)
{
// 发送邮件或短信通知用户
Mail::to($event->order->user)->send(
new ShippingNotification($event->order)
);
}
}
打开 app/Providers/EventServiceProvider.php,在 $listen 数组中注册事件和对应的监听器:
protected $listen = [
'App\Events\OrderShipped' => [
'App\Listeners\SendShippingNotification',
],
];
注册后,当事件被触发时,Laravel 会自动调用所有关联的监听器。
在控制器或其他业务逻辑中,使用 event() 辅助函数或 Event 门面来触发事件:
use App\Events\OrderShipped;
// ...
public function ship(Order $order)
{
// 处理发货逻辑...
event(new OrderShipped($order));
// 或者:Event::dispatch(new OrderShipped($order));
}
一旦事件被触发,所有注册的监听器将按顺序执行。
Laravel 支持自动事件发现。如果你不想手动注册,可在 EventServiceProvider 中启用:
public function shouldDiscoverEvents()
{
return true;
}
Laravel 会自动扫描 Listeners 目录并根据注解绑定事件。
基本上就这些。Laravel 的事件与监听器机制让代码更清晰、更易维护,适合将主流程和副作用逻辑分离。不复杂但容易忽略细节,比如事件是否序列化、监听器是否应异步执行等,可根据实际需求结合队列使用。
以上就是laravel如何实现事件(Events)和监听器(Listeners)_Laravel事件与监听器实现方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号