您的位置:首页 > 技术中心 > php框架 >

一起学习laravel中的事件以及观察者吧!

时间:2022-03-03 11:48

下面由laravel教程栏目给大家介绍laravel中的事件以及观察者,希望对需要的朋友有所帮助!

一:事件与监听器

事件是一个比较广泛的的名词,他可以代表所做的一个动作。和事件一起出现的就是监听器了,其作用是用来监听你所做的事情,用来对你的行为做后续处理。
事件系统为应用各个方面的解耦提供了非常棒的方法,因为单个事件可以拥有多个互不依赖的监听器。例如,你可能希望每次订单发货时向用户发送一个通知。你可以编写一个可以被监听的事件,而不是将订单处理代码通知代码耦合在一起。

事件:
Laravel 框架想要创建事件可以通过以下命令来创建:

php artisan make:event 事件名称

该文件会存放在 app/Events 目录下面。

监听器:

创建监听器可以使用以下命令来创建:

php artisan make:listener 监听器名称

注册:

事件和监听器在创建完毕后,还需要将二者联合起来。我们可以在 EventServiceProvider 服务提供者中进行注册。如下:

    protected $listen = [
        事件名称 => [
            监听器名称,
         .
        ],
    ];

分发

event(new TestEvent());

二:模型事件

模型事件是专门针对模型而额外添加的功能。其给我们创建了对应的事件与监听。在使用模型事件事,我们需要遵守模型给我们的规则:

  • retrieved: 获取到模型实例后触发
  • creating: 插入到数据库前触发
  • created: 插入到数据库后触发
  • updating: 更新到数据库前触发
  • updated: 更新到数据库后触发
  • saving: 保存到数据库前触发(插入/更新之前,无论插入还是更新都会触发)
  • saved: 保存到数据库后触发(插入/更新之后,无论插入还是更新都会触发)
  • deleting: 从数据库删除记录前触发
  • deleted: 从数据库删除记录后触发
  • restoring: 恢复软删除记录前触发
  • restored: 恢复软删除记录后触发

需要在模型处绑定

protected $dispatchesEvents = [
        'saving' => \App\Events\TestEvent::class,
//        'updated' => \App\Events\TestEvent::class,
];

三:观察者

事件需要与监听器关联来,当监听器变多了我们还需进行注册实现,这样会比较麻烦,这时我们可以考虑使用观察者。如果在一个模型上监听了多个事件,可以使用观察者来将这些监听器组织到一个单独的类中。

观察者使用:

观察者的创建可以使用以下命令来创建:

php artisan make:observer

如果想要直接跟模型关联起来,还可以直接加入参数与模型关联:

php artisan make:observer UserObserver --model=User

观察者注册:
在服务提供者中注册

User::observe(UserObserver::class);

或在模型中注册

public static function booted()
{
     self::observe(UserObserver::class);
}

相关推荐:最新的五个Laravel视频教程

以上就是一起学习laravel中的事件以及观察者吧!的详细内容,更多请关注www.gxlsystem.com其它相关文章!

本类排行

今日推荐

热门手游