Skip to content

Event List

Vitaly Tomilov edited this page Aug 10, 2019 · 13 revisions

When working with a list of events, you may decide to access them by name. Modern TypeScript lets you do this, while still controlling the event type, with the help of keyof, as shown in the example below.

class Events {
    first = new SubEvent<number>();
    second = new SubEvent<string>();
    third = new SubEvent<boolean>();

    get<K extends keyof Events>(key: K) {
        return this[key];
    }
}

Then after creating a class object:

const events = new Events();

you can access each event via a string:

events.get('first').subscribe((data: number) => {
    // data is type-controlled
});

events.get('second').subscribe((data: string) => {
    // data is type-controlled
});

events.get('third').subscribe((data: boolean) => {
    // data is type-controlled
});
Clone this wiki locally