承接 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.

统计信息

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

GitHub 信息

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

其他信息

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

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固