1 事件与监听器
事件是一个比较广泛的的名词,他可以代表所做的一个动作。和事件一起出现的就是监听器了,其作用是用来监听你所做的事情,用来对你的行为做后续处理。
事件系统为应用各个方面的解耦提供了非常棒的方法,因为单个事件可以拥有多个互不依赖的监听器。例如,你可能希望每次订单发货时向用户发送一个通知。你可以编写一个可以被监听的事件,而不是将订单处理代码通知代码耦合在一起。
事件:
Laravel 框架想要创建事件可以通过以下命令来创建:
php artisan make:event 事件名称
该文件会存放在 app/Events 目录下面。
监听器:
创建监听器可以使用以下命令来创建:
php artisan make:listener 监听器名称
注册:
事件和监听器在创建完毕后,还需要将二者联合起来。我们可以在 EventServiceProvider 服务提供者中进行注册。如下:
protected $listen = [
事件名称 => [
监听器名称,
.
],
];
分发
event(new TestEvent());
2 模型事件
模型事件是专门针对模型而额外添加的功能。其给我们创建了对应的事件与监听。在使用模型事件事,我们需要遵守模型给我们的规则:
- retrieved: 获取到模型实例后触发
- creating: 插入到数据库前触发
- created: 插入到数据库后触发
- updating: 更新到数据库前触发
- updated: 更新到数据库后触发
- saving: 保存到数据库前触发(插入/更新之前,无论插入还是更新都会触发)
- saved: 保存到数据库后触发(插入/更新之后,无论插入还是更新都会触发)
- deleting: 从数据库删除记录前触发
- deleted: 从数据库删除记录后触发
- restoring: 恢复软删除记录前触发
- restored: 恢复软删除记录后触发
需要在模型处绑定
protected $dispatchesEvents = [
'saving' => \App\Events\TestEvent::class,
// 'updated' => \App\Events\TestEvent::class,
];
3 观察者
事件需要与监听器关联来,当监听器变多了我们还需进行注册实现,这样会比较麻烦,这时我们可以考虑使用观察者。如果在一个模型上监听了多个事件,可以使用观察者来将这些监听器组织到一个单独的类中。
观察者使用:
观察者的创建可以使用以下命令来创建:
php artisan make:observer
如果想要直接跟模型关联起来,还可以直接加入参数与模型关联:
php artisan make:observer UserObserver --model=User
观察者注册:
在服务提供者中注册
User::observe(UserObserver::class);
或在模型中注册
public static function booted()
{
self::observe(UserObserver::class);
}
网友评论