event-target-shim
Version:
An implementation of WHATWG EventTarget interface.
78 lines (52 loc) • 2.9 kB
Markdown
# event-target-shim
[](https://www.npmjs.com/package/event-target-shim)
[](http://www.npmtrends.com/event-target-shim)
[](https://github.com/mysticatea/event-target-shim/actions)
[](https://codecov.io/gh/mysticatea/event-target-shim)
[](https://david-dm.org/mysticatea/event-target-shim)
An implementation of [WHATWG `EventTarget` interface](https://dom.spec.whatwg.org/#interface-eventtarget) and [WHATWG `Event` interface](https://dom.spec.whatwg.org/#interface-event). This implementation supports constructor, `passive`, `once`, and `signal`.
This implementation is designed ...
- Working fine on both browsers and Node.js.
- TypeScript friendly.
## 💿 Installation
Use [npm](https://www.npmjs.com/) or a compatible tool.
```
npm install event-target-shim
```
## 📖 Getting started
```js
import { EventTarget, Event } from "event-target-shim";
// constructor (was added to the standard on 8 Jul 2017)
const myNode = new EventTarget();
// passive flag (was added to the standard on 6 Jan 2016)
myNode.addEventListener(
"hello",
(e) => {
e.preventDefault(); // ignored and print warning on console.
},
{ passive: true }
);
// once flag (was added to the standard on 15 Apr 2016)
myNode.addEventListener("hello", listener, { once: true });
myNode.dispatchEvent(new Event("hello")); // remove the listener after call.
// signal (was added to the standard on 4 Dec 2020)
const ac = new AbortController();
myNode.addEventListener("hello", listener, { signal: ac.signal });
ac.abort(); // remove the listener.
```
- For browsers, use a bundler such as [Webpack](https://webpack.js.org/) to bundle.
- If you want to support IE11, use `import {} from "event-target-shim/es5"` instead. It's a transpiled code by babel. It depends on `@baebl/runtime` (`^7.12.0`) package.
- The `AbortController` class was added to the standard on 14 Jul 2017. If you want the shim of that, use [abort-controller](https://www.npmjs.com/package/abort-controller) package.
## 📚 API Reference
See [docs/reference.md](docs/reference.md).
## 💥 Migrating to v6
See [docs/migrating-to-v6.md](docs/migrating-to-v6.md).
## 📰 Changelog
See [GitHub releases](https://github.com/mysticatea/event-target-shim/releases).
## 🍻 Contributing
Contributing is welcome ❤️
Please use GitHub issues/PRs.
### Development tools
- `npm install` installs dependencies for development.
- `npm test` runs tests and measures code coverage.
- `npm run watch:mocha` runs tests on each file change.