模式:大概是通过一个自定义的event,一个handler,还有一个binder,然后用来简化通知模型

生成自定义的event

./artisan make:event MyEvent

生成自定义的handler

./artisan handler:event MyEventHandler --event=MyEvent

然后在EventServiceProvider里面添加,可以添加多个,演示就只注册一个了

protected $listen = [
'App\Events\MyEvent' => [
'App\Handlers\Events\MyEventHandler',
],
];

如果你要多个handler,可以先在EventServiceProvider里面写好,然后命令

./artisan event:generate

触发event

$aaaa = 'sfsdfsdf';
$response = Event::fire(new App\Events\MyEvent($aaaa));

你会发现,在handler的handle方法被触发,不过看phpdoc,这个方法似乎是void返回,不知道这个response有什么用处

--------------------------------------------------------------------------------------------------------------------------------------------

注册event事件组

保留上面的MyEvent,别的不要了

注册我们的MyEventGroupHandler,这里演示一个event,subscribe方法必须定义

<?php namespace App;

class MyEventGroupHandler {

    /**
* Handle user login events.
*/
public function onMyEvent($event)
{
echo "MyEventGroupHandler";
dd($event);
} /**
* Register the listeners for the subscriber.
*
* @param Illuminate\Events\Dispatcher $events
* @return array
*/
public function subscribe($events)
{
$events->listen('App\Events\MyEvent', 'App\MyEventGroupHandler@onMyEvent');
}
}

动态注册监听event

$subscriber = new App\MyEventGroupHandler;
Event::subscribe($subscriber);

触发事件

$podcast = 'sfsdfsdf';
$response = Event::fire(new App\Events\MyEvent($podcast));

xdebug发现,MyEventGroupHandler的onMyEvent被断下

如果原来的myEventHandler也被注册,也能得到通知。

发现两种方式似乎没太大区别,一个静态注册,另一个动态注册,留着以后再说吧

05-22 17:18