定制 lithemod/events 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

lithemod/events

最新稳定版本:v1.1.0

Composer 安装命令:

composer require lithemod/events

包简介

Lithe Events: A powerful and lightweight event management system for PHP projects, designed to simplify communication between components intuitively and efficiently. Easily create, register, and emit events, making your code more modular and reactive. Transform your applications into dynamic experie

README 文档

README

Lithe Events is a lightweight event handling library designed for PHP applications. It provides a straightforward way to create and manage events, supporting a decoupled architecture that enhances the maintainability and flexibility of your applications.

Table of Contents

Installation

To install lithemod/events, use Composer. Run the following command in your project directory:

composer require lithemod/events

This command will download the package and update your composer.json file accordingly.

Usage

Using the EventDispatcher Class

The EventDispatcher class serves as the core for managing events and listeners. Here's how to use it effectively:

Creating an Event

To create an event, instantiate the Event class:

use Lithe\Events\Event;

$event = new Event('event.name', ['key' => 'value']);
  • Parameters:
    • event.name: A string that identifies the event.
    • ['key' => 'value']: An optional associative array to store additional event data.

Registering Listeners

You can create an instance of EventDispatcher and register a listener for an event using the on method. A listener is a callable executed when the event is emitted.

use Lithe\Events\EventDispatcher;

$dispatcher = new EventDispatcher();

$listener = function ($data) {
    echo "Event data: " . json_encode($data);
};

// Register the listener
$dispatcher->on('event.name', $listener);

Emitting Events

To emit an event and trigger all registered listeners, use the emit method:

$event = new Event('event.name', ['key' => 'value']);
$dispatcher->emit($event);

Removing Listeners

If you need to remove a listener from an event, use the off method:

$dispatcher->off('event.name', $listener);

Using Orbis Event Functions

In addition to using the EventDispatcher, you can utilize helper functions provided by the Orbis namespace for convenient event management.

Registering Listeners

To register a listener for an event using Orbis, use the on function:

use Lithe\Orbis\Events;

$listener = function ($data) {
    echo "Event data: " . json_encode($data);
};

// Register the listener
Events\on('event.name', $listener);

Emitting Events

To emit an event using Orbis, call the emit function:

use Lithe\Orbis\Events;
use Lithe\Events\Event;

$event = new Event('event.name', ['key' => 'value']);
Events\emit($event);

Removing Listeners

To remove a registered listener with Orbis, use the off function:

Events\off('event.name', $listener);

Example

Here's a complete example of how to use lithemod/events with the Orbis event functions:

use Lithe\Events\Event;
use Lithe\Orbis\Events;

// Create a listener
$listener = function ($data) {
    echo "Event received with data: " . json_encode($data) . "\n";
};

// Register the listener
Events\on('my.event', $listener);

// Emit the event
$data = ['msg' => 'Hello, world!'];
Events\emit(new Event('my.event', $data));

// Remove the listener
Events\off('my.event', $listener);

License

This project is licensed under the MIT License.

统计信息

  • 总下载量: 13
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-10-20