thinkphp6 事件

本文详细介绍了 Laravel 框架中的事件系统,包括事件监听器的创建与触发,以及如何使用命令行创建监听类。文中通过实例展示了如何注册监听器、触发事件,并解释了事件订阅类的优势,如处理多个监听类和灵活性。此外,还提及了系统内置的自动触发事件以及如何通过订阅类来监听和响应特定事件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

事件和中间件有一点相似,事件更加的精准定位更细腻的业务场景;

事件可定义:事件类、事件监听类、事件订阅类;

我们先创建一个测试事件的类:TestEvent.php,手动创建一个测试类;

<?php
	public function __construct()
	{
		//注册监听器
		Event::listen('TestListen', function ($param) {
			echo '我是监听器,我被触发了!'.$param;
		});
		}
	public function info()
	{
		echo '登录前准备!';
		Event::trigger('TestListen', 'ok'); //触发监听器
		event('TestListen'); //助手函数触发
	}
?>

也可以使用监听类来设计监听器,使用命令行创建;

php think make:listener TestListen
public function info()
{
	echo '登录前准备!';
	Event::listen('TestListen', TestListen::class); //这句可以定义到配置文件
	Event::trigger('TestListen');
}

在 app/event.php 中,listen 是配置监听类的,配置方式如下:

'listen' => [
'TestListen' => [\app\listener\TestListen::class]
], 

而监听类被触发会自动执行 handle()方法,实现监听功能;

public function handle($event)
{
	echo '我是监听类!'.$event;
}

系统还内置了系统触发的事件,只要满足条件就会自动触发;
事件监听类,可以同时监听多个监听类,只要绑定到一个标识符即可;

'TestListen' => [
	\app\listener\TestListen::class,
	\app\listener\TestOne::class,
	\app\listener\TestTwo::class
]

对于需要多个监听,监听类不够灵活,而且类会创建很多,可以使用订阅类;

订阅类就是将监听事件作为内部的方法用 on+方法名来实现;

php think make:subscribe UserSub
class UserSub{
	public function onUserLogin(){
		echo '处理登录后的监听!';
	}
	public function onUserLogout(){
		echo '处理退出后的监听!';
	}
}

然后,直接去 app/event.php 注册一下;

'subscribe' => [
	'UserSub' => \app\subscribe\UserSub::class,
], 

然后,两个方法分别监听两个事件方法,直接调用方法名即可;

public function login(){
	echo '登录成功!';
	Event::trigger('UserLogin');
}
public function logout(){
	echo '退出成功!';
	Event::trigger('UserLogout');
}

对于事件类,很少有场景需要使用它,毕竟系统提供的各种精确方案较多;

php think make:event UserEvent
class UserEvent{
	public function __construct()
	{
		echo '我是事件类!';
	}
}
Event::trigger(new UserEvent());
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值