Socket
Socket
Sign inDemoInstall

microevent.ts

Package Overview
Dependencies
0
Maintainers
1
Versions
4
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    microevent.ts

Zero cost events


Version published
Weekly downloads
2.7M
decreased by-2.71%
Maintainers
1
Install size
9.66 kB
Created
Weekly downloads
 

Changelog

Source

0.2.1

Include changelog in NPM package.

Readme

Source

Build Status npm version

What is it?

This package implements an event system with minimal dispatch overhead. Instead of recording handlers bound to an event in dynamic data structures, this library binds the handlers to autogenerated code. This enables the VM to inline the handler invocation and generate code that is just as fast as invoking the handlers directly.

In a (completely unscientific) benchmark, this library performs bettern than NodeJS events in terms of event dispatch calls per second by about two orders of magnitude.

How to use it?

Installation

You can install the library into your project via npm

npm install microevent.ts

The library is written in Typescript and will work in any environment that supports ES5. No external typings are required for using this library with Typescript (version >= 2).

Importing

ES5 / CommonJS

var Event = require('microevent.ts').Event;

ES6

import {Event} from 'microevent.ts';

Typescript

import {Event, EventInterface} from 'microevent.ts';

The EventInterface covers only the client side of an event, that is adding and removing handlers.

API

Creating

ES5/ES6

const event = new Event();

Typescript

const event = new Event<PayloadT>();

Create a new event that will dispatch a payload of type PayloadT.

Dispatching

event.dispatch(payload);

This will call all handlers in the order they were registered, passing payload as first argument.

IMPORTANT dispatch is a property that refers to dynamically generated code. DO NOT KEEP ANY REFERENCES to dispatch as adding and removing handlers will invalidate them.

Registering handlers

event.addHandler(handler, context);

context is an optional parameter that will be passed to the handler on each invocation.

Removing handlers

event.removeHandler(handler, context);

Both handler and context must be identical to the values used when registering the handler in the first place.

Checking for handlers

event.isHandlerAttached(handler, context)

This will check whether a handler was attached in a given context.

event.hasHandlers

true if the event has any handlers attached, false otherwise.

License

Feel free to use this library under the conditions of the MIT license.

Keywords

FAQs

Last updated on 19 May 2019

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