PHPackages                             pagon/eventemitter - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Utility &amp; Helpers](/categories/utility)
4. /
5. pagon/eventemitter

ActiveLibrary[Utility &amp; Helpers](/categories/utility)

pagon/eventemitter
==================

Event Emitter for PHP

0.5.2(12y ago)2919.3k↓50%53MITPHPPHP &gt;=5.3.0

Since Jan 9Pushed 12y ago4 watchersCompare

[ Source](https://github.com/hfcorriez/php-eventemitter)[ Packagist](https://packagist.org/packages/pagon/eventemitter)[ RSS](/packages/pagon-eventemitter/feed)WikiDiscussions master Synced 1mo ago

READMEChangelogDependenciesVersions (11)Used By (3)

Other Languages：[English](./README_en.md)

介绍 [![Build Status](https://camo.githubusercontent.com/02310fba67e8ed50b33d4866c3260741c3c0868cfefdd87ea22bf9512900fbf7/68747470733a2f2f7472617669732d63692e6f72672f6866636f727269657a2f7068702d6576656e74656d69747465722e706e67)](https://travis-ci.org/hfcorriez/php-eventemitter)
====================================================================================================================================================================================================================================================================================

[](#介绍-)

简单的事件管理器

安装
==

[](#安装)

添加 `"pagon/eventemitter": "*"` 到 `composer.json`

```
composer.phar install

```

使用方式
====

[](#使用方式)

触发和绑定
-----

[](#触发和绑定)

### 简单方式

[](#简单方式)

很简单的使用方式

```
$event = new EventEmitter();

// 绑定事件
$event->on('new', function () {
    echo 'A new client is coming' . PHP_EOL;
});

// 触发
$event->emit('new');
```

### 单次绑定

[](#单次绑定)

绑定的事件只会被触发一次，适合第一次做一些事情的时候去使用

```
$event = new EventEmitter();

// 绑定单次事件
$event->once('new', function () {
    echo 'A new client is coming' . PHP_EOL;
});

// 触发
$event->emit('new');

// 不触发
$event->emit('new');
```

### 多次绑定

[](#多次绑定)

绑定的事件被触发N次，适合一些有固定用途的事件

```
$event = new EventEmitter();

// 绑定2次事件
$event->many('new', 2, function () {
    echo 'A new client is coming' . PHP_EOL;
});

$event->emit('new'); // 触发
$event->emit('new'); // 触发
$event->emit('new'); // 不触发
```

### 模糊绑定

[](#模糊绑定)

绑定一个模糊的事件名称，可以匹配上的事件都会被触发

```
$event = new EventEmitter();

// 绑定模糊事件
$event->on('news.*', function($id){
    echo $id . ' is comming..., ID is ';
});

$event->emit('news.1');
$event->emit('news.2');
$event->emit('news.3');
```

删除
--

[](#删除)

### 注销事件

[](#注销事件)

当事件不用的时候可以注销掉

```
$event = new EventEmitter();

// 闭包回调
$operator = function () {
    echo 'A new client is coming' . PHP_EOL;
};

$event->on('new', $operator);

$event->emit('new');           // 触发

$event->off('new', $operator); // 解除绑定
$event->emit('new');           // 不触发
```

### 删除事件

[](#删除事件)

删除指定类型的所有事件

```
$event = new EventEmitter();

$event->on('new', function () {
    echo 'A new client is coming' . PHP_EOL;
});

$event->removeAllListeners('new');
```

### 删除所有事件

[](#删除所有事件)

清空事件

```
$event = new EventEmitter();

$event->on('new', function () {
    echo 'A new client is coming' . PHP_EOL;
});

$event->on('close', function () {
    echo 'The client has closed' . PHP_EOL;
});

$event->removeAllListeners();
```

### 继承事件功能

[](#继承事件功能)

适用于为自己的对象增加事件功能

```
class MyClass extends EventEmitter {
}

$my = new MyClass;
$my->on('create', function($data){
    $db->save($data);
});
```

全局管理器
-----

[](#全局管理器)

### 全局事件

[](#全局事件)

可以作为默认是件管理器使用

```
// 注册事件
Event::on('save', function ($arg) {
    echo '1 saved: ' . $arg . PHP_EOL;
});

// 触发事件
Event::emit('save', 'test');
```

### 更换全局事件管理器

[](#更换全局事件管理器)

```
$emitter = new EventEmitter();
// 更换触发器
Event::emitter($emitter);

// 绑定事件
$event->on('save', function ($arg) {
    echo '1 saved: ' . $arg . PHP_EOL;
});

// 触发save
$event->emit('save', 'test');

// 效果同上
$emitter->emit('save', 'test');
```

License
=======

[](#license)

(The MIT License)

Copyright (c) 2012 hfcorriez &lt;&gt;

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the 'Software'), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

###  Health Score

34

—

LowBetter than 77% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity36

Limited adoption so far

Community16

Small or concentrated contributor base

Maturity54

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~28 days

Recently: every ~36 days

Total

10

Last Release

4618d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/052da9fcd2d35025de486c255a8b4d38a67b2626b6ca626f6681bbc00187e62b?d=identicon)[hfcorriez](/maintainers/hfcorriez)

---

Top Contributors

[![hfcorriez](https://avatars.githubusercontent.com/u/119550?v=4)](https://github.com/hfcorriez "hfcorriez (26 commits)")

---

Tags

eventevent-emitterHOOK

### Embed Badge

![Health badge](/badges/pagon-eventemitter/health.svg)

```
[![Health](https://phpackages.com/badges/pagon-eventemitter/health.svg)](https://phpackages.com/packages/pagon-eventemitter)
```

###  Alternatives

[doctrine/event-manager

The Doctrine Event Manager is a simple PHP event system that was built to be used with the various Doctrine projects.

6.1k501.1M115](/packages/doctrine-event-manager)[league/event

Event package

1.6k141.6M184](/packages/league-event)[evenement/evenement

Événement is a very simple event dispatching library for PHP

1.4k147.0M319](/packages/evenement-evenement)[laminas/laminas-eventmanager

Trigger and listen to events within a PHP application

1.0k69.8M225](/packages/laminas-laminas-eventmanager)[tormjens/eventy

The WordPress filter/action system in Laravel

438912.9k16](/packages/tormjens-eventy)[dazzle-php/event

Dazzle Events &amp; Dispatchers.

161.7k6](/packages/dazzle-php-event)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
