微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

下面由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视频教程

原文地址:https://www.jb51.cc/laravel/1199146.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。