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

Laravel 的事件系统提供了一种优雅的方式来解耦应用中的各种操作。通过事件和监听器机制,你可以定义某个动作发生时触发的“事件”,然后由一个或多个“监听器”来响应这个事件。这种模式非常适合处理日志记录、发送通知、更新缓存等场景。
1. 创建事件(Events)
事件类通常存放在 app/Events 目录下。你可以使用 Artisan 命令创建一个事件:
php artisan make:event OrderShipped
执行后会生成 app/Events/OrderShipped.php 文件。你可以在构造函数中注入需要的数据:
class OrderShipped{ public $order; public function __construct(Order $order) { $this->order = $order; }}
2. 创建监听器(Listeners)
监听器用于响应特定事件。使用以下命令创建监听器:
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) ); }}
3. 注册事件与监听器
打开 app/Providers/EventServiceProvider.php,在 $listen 数组中注册事件和对应的监听器:
protected $listen = [ 'AppEventsOrderShipped' => [ 'AppListenersSendShippingNotification', ],];
注册后,当事件被触发时,Laravel 会自动调用所有关联的监听器。
4. 触发事件
在控制器或其他业务逻辑中,使用 event() 辅助函数或 Event 门面来触发事件:
use AppEventsOrderShipped;// ...public function ship(Order $order){ // 处理发货逻辑... event(new OrderShipped($order)); // 或者:Event::dispatch(new OrderShipped($order));}
一旦事件被触发,所有注册的监听器将按顺序执行。
5. 事件发现(可选)
Laravel 支持自动事件发现。如果你不想手动注册,可在 EventServiceProvider 中启用:
public function shouldDiscoverEvents(){ return true;}
Laravel 会自动扫描 Listeners 目录并根据注解绑定事件。
基本上就这些。Laravel 的事件与监听器机制让代码更清晰、更易维护,适合将主流程和副作用逻辑分离。不复杂但容易忽略细节,比如事件是否序列化、监听器是否应异步执行等,可根据实际需求结合队列使用。
以上就是laravel如何实现事件(Events)和监听器(Listeners)_Laravel事件与监听器实现方法的详细内容,更多请关注php中文网其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/141022.html
微信扫一扫
支付宝扫一扫