TP6 事件绑定监听订阅

Posted 风吹头蛋凉

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了TP6 事件绑定监听订阅相关的知识,希望对你有一定的参考价值。

事件是什么

事件相比较中间件的优势是事件比中间件更加精准定位(或者说粒度更细),并且更适合一些业务场景的扩展。例如,我们通常会遇到用户注册或者登录后需要做一系列操作,通过事件系统可以做到不侵入原有代码完成登录的操作扩展,降低系统的耦合性的同时,还能完成业务的需求。

TP6中事件的使用

官网的解释,没有实例,这里简单的告诉大家如何使用,会使用之后再去发现更多操作

1.事件监听

  • 命令行生成监听 php think make:listener UserLogin

一般建议直接在事件定义文件(event.php)中定义对应事件的监听。

return [
    'bind'    =>    [
        'UserLogin' => 'app\\event\\UserLogin',
        // 更多事件绑定
    ],
    'listen'  =>    [
        'UserLogin'    =>    ['app\\listener\\UserLogin'],
        // 更多事件监听
    ],
];

2.事件订阅

  • 命令行php think make:subscribe User
    默认会生成app\\subscribe\\User类,或者你可以指定完整类名生成。
<?php
namespace app\\subscribe;

class User
{
    public function onUserLogin($user)
    {
        // UserLogin事件响应处理
    }

    public function onUserLogout($user)
    {
        // UserLogout事件响应处理
    }
}

3.自定义订阅

如果希望自定义订阅方式(或者方法规范),可以定义subscribe方法实现。

<?php
namespace app\\subscribe;

use think\\Event;

class User
{
    public function onUserLogin($user)
    {
        // UserLogin事件响应处理
    }

    public function onUserLogout($user)
    {
        // UserLogout事件响应处理
    }

    public function subscribe(Event $event)
    {
        $event->listen('UserLogin', [$this,'onUserLogin']);
        $event->listen('UserLogout',[$this,'onUserLogout']);
    }
}

然后在事件定义文件注册事件订阅者

return [
    'bind'    =>    [
        'UserLogin' => 'app\\event\\UserLogin',
        // 更多事件绑定
    ],
    'listen'  =>    [
        'UserLogin'    =>    ['app\\listener\\UserLogin'],
        // 更多事件监听
    ],
    'subscribe'    =>    [
       'app\\subscribe\\User',
        // 更多事件订阅
    ],
];

事件触发

// 触发UserLogin事件 用于执行用户登录后的一系列操作
Event::trigger('UserLogin');
或者使用助手函数
event('UserLogin');

以上是关于TP6 事件绑定监听订阅的主要内容,如果未能解决你的问题,请参考以下文章

TP6 事件绑定监听订阅

Vue双向绑定的实现原理系列:监听器Observer和订阅者Watcher

数据绑定原理

时间绑定和事件监听!

Vue响应式原理/双向数据绑定

事件绑定事件监听和事件委托