1.1.2 • Published 2 years ago
subscribe-event v1.1.2
Subscribe-event
Subscribe-event is the easiest way to subscribe either dom events in browser or node.js events.
Live example: http://xnimorz.github.io/subscribe-event/
Install
npm install --save subscribe-event
// or for yarn:
yarn add subscribe-eventLibrary support es6, CommonJs, AMD modules
Getting started
Step 1: import module:
import subscribe from "subscribe-event";Step 2: call subscrube function:
const unsubscribe = subscribe(document, "scroll", () => {
/* Do some job */
});Step 3: call unsubscibe, which returned from subscribe function, to dispose:
unsubscribe();API
subscribe is a function, which receives 4 arguments:
- element — is a HTMLElement such as document.body, document, etc., Node.js object or any another object, that triggers events.
- event — is an event, such as
scroll,click,mousemoveetc. - eventCallback — a function called when event triggers
- options — unessesary parameter, which provides more data to subscribe function. For example, when you using
subscribefor HTMLElements you can capture events:subscibe(document.querySelector('#a'), 'click', () => console.log('clicked'), true)
Usage with React
import React, { Component } from "react";
import subscribe from "subscribe-event";
class MyAmazingComponent extends Component {
componentDidMount() {
this.unsubscribeScroll = subscribe(document, "scroll", () => {
// do some job
});
}
componentWillUnmount() {
this.unsubscribeScroll();
}
render() {
const { children } = this.props;
return <div>{children}</div>;
}
}Subscribe-event is useful for capturing events:
import React, { Component } from "react";
import subscribe from "subscribe-event";
class MyAmazingComponent extends Component {
componentDidMount() {
this.unsubscribe = subscribe(
document,
"scroll",
() => {
// do some job
},
true
);
}
componentWillUnmount() {
this.unsubscribe();
}
render() {
const { children } = this.props;
return <div>{children}</div>;
}
}Examples
For example in browser:
import subscribe from "subscribe-event";
var element = document.querySelector(".my-button");
var unsubscribe = subscribe(element, "click", e => {
console.log(e);
});
// code
unsubscribe();or
import subscribe from "subscribe-event";
var unsubscribe = subscribe(document, "scroll", e => {
console.log(e);
});
// code
unsubscribe();This library supports old ie also (attachEvent/detachEvent).
You can define your custom event subscribe function:
import subscribe from 'subscribe-event';
var obj: {
eventSubscribe: function() {...},
eventUnsubscribe: function() {...}
}
var customSubscribe = subscribe.define('eventSubscribe', 'eventUnsubscribe');
var customUnsubscribe = customSubscribe(obj, event, handler);
// ...
customUnsubscribe();By default subscribe-event works with: addEventListener, detachEvent, on