Socket
Socket
Sign inDemoInstall

component-emitter

Package Overview
Dependencies
0
Maintainers
33
Versions
7
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    component-emitter

Simple event emitter


Version published
Weekly downloads
20M
increased by2.85%
Maintainers
33
Install size
9.34 kB
Created
Weekly downloads
 

Package description

What is component-emitter?

The component-emitter package is a simple event emitter implementation that allows objects to subscribe to events, emit events, and remove event listeners. It is often used to add observer pattern capabilities to objects, enabling event-driven programming.

What are component-emitter's main functionalities?

Event subscription

This feature allows an object to listen for specific events using the 'on' method. When the event is emitted, the callback function is called.

const Emitter = require('component-emitter');
let emitter = new Emitter();
emitter.on('event', function(message) {
  console.log(message);
});

Event emission

This feature allows an object to emit an event, optionally passing arguments to the event listeners.

emitter.emit('event', 'Hello World!');

One-time event subscription

This feature allows an object to listen for an event only once. After the event is emitted and the listener is invoked, the listener is removed.

emitter.once('event', function(message) {
  console.log(message);
});

Event unsubscription

This feature allows an object to stop listening for specific events using the 'off' method.

function listener(message) {
  console.log(message);
}
emitter.on('event', listener);
emitter.off('event', listener);

Other packages similar to component-emitter

Readme

Source

component-emitter

Simple event emitter

Install

npm install component-emitter

Usage

As an Emitter instance:

import Emitter from 'component-emitter';

const emitter = new Emitter();

emitter.emit('🦄');

As a mixin:

import Emitter from 'component-emitter';

const user = {name: 'tobi'};
Emitter(user);

user.emit('I am a user');

As a prototype mixin:

import Emitter from 'component-emitter';

Emitter(User.prototype);

API

new Emitter()

Create a new emitter.

Emitter(object)

Use it as a mixin. For example a plain object may become an emitter, or you may extend an existing prototype.

Emitter#on(event, listener)

Register an event handler that listens to a specified event.

Emitter#once(event, listener)

Register a one-time event handler for a specified event.

Emitter#off(event, listener)

Remove a specific event handler for a specified event.

Emitter#off(event)

Remove all event handlers for a specified event.

Emitter#off()

Remove all event handlers for all events.

Emitter#emit(event, ...arguments)

Emit an event, invoking all handlers registered for it.

Emitter#listeners(event)

Retrieve the event handlers registered for a specific event.

Emitter#listenerCount(event)

Get the count of listeners for a specific event.

Emitter#listenerCount()

Get the count of all event handlers in total.

Emitter#hasListeners(event)

Check if there are any handlers registered for a specific event.

Emitter#hasListeners()

Check if there are any handlers registered for any event.

FAQ

How does it differ from the Node.js EventEmitter?

It's simpler and more lightweight, and it works in any JavaScript environment, not just Node.js. It also provides mixin functionality to add event handling to existing objects without needing inheritance.

Keywords

FAQs

Last updated on 17 Nov 2023

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc