Tags: events
Create an async iterable of events from an EventTarget.
import { on } from "event-gen";
for await (const event of on(document, "click")) {
// do something with the click event
}
// also available as methods (using a Proxy)
for await (const event of on.click(document)) {
// do something with the click event
}
Supports passing an abort signal to stop listening for events.
for await (const event of on.click(document, {
// stop listening after 1 second
signal: AbortSignal.timeout(1000),
})) {
// do something with the click event
}
Type inference
The event type is inferred from the target's on${TEventType}
property (e.g. onclick
).
for await (const event of on.click(document)) {
// event is inferred as PointerEvent
}
If the event type cannot be inferred, it defaults to Event
. You can assert the event type by providing a type parameter.
for await (const event of on.click<PointerEvent>(customTarget)) {
// event is asserted as PointerEvent
}
Methods
A Proxy is used to allow providing the type via calling a method instead of passing it as a parameter. (e.g. on.click(document)
instead of on(document, "click")
). This allows any type in runtime, but in Typescript the keys need to be known at compile time for inference to work. Additionally, if you're using noUncheckedIndexedAccess
, unknown keys will be marked as potentially undefined due to the index signature.
for await (const event of on.custom(customTarget)) {
// event is defaulted as Event
}
// can be asserted
for await (const event of on.custom<CustomEvent>(customTarget)) {
// event is asserted as CustomEvent
}
By default the known types are limited to the ones from window
and document
. You can expand this by adding to the KnownEvents
interface.
declare module "event-gen" {
export interface KnownEvents {
custom: true;
}
}
for await (const event of on.custom(customTarget)) {
// now knows to look at customTarget.oncustom to infer the event type
}
Back to all packages