169 похожих чатов

Накропал типизированный EventTarget, покритикуйте /** * Factory constructs EventTarget with typed

methods according given EventMap
*/
export default function typedEventTargetFactory<EventMap extends { [K: string]: any }, EM extends { [K: string]: any } = EventMap & { all: EventMap[keyof EventMap] }>() {
const symbol = Symbol("ownCustomEvent");

class TypedEvent<K extends keyof EM = keyof EM> extends CustomEvent<EM[K]> {
[symbol] = true;

constructor(type: K, ...eventInitDict: EM[K] extends Record<string, never> | null | undefined ? [undefined?] : [CustomEventInit<EM[K]>]) {
super(type as string, ...eventInitDict);
}
}

class TypedEventTarget extends EventTarget {
static TypedEvent = TypedEvent;

addEventListener<K extends keyof EM>(type: K, listener: ((this: typeof this, ev: TypedEvent<K>) => any) | { handleEvent: (ev: CustomEvent<EM[K]>) => any } | null, options?: boolean | EventListenerOptions) {
return super.addEventListener(type as string, listener as EventListenerOrEventListenerObject, options);
}

removeEventListener<K extends keyof EM>(type: K, listener: ((this: typeof this, ev: TypedEvent<K>) => any) | { handleEvent: (ev: CustomEvent<EM[K]>) => any } | null, options?: boolean | EventListenerOptions) {
return super.removeEventListener(type as string, listener as EventListenerOrEventListenerObject, options);
}

dispatchEvent(event: TypedEvent) {
super.dispatchEvent(new CustomEvent("all", {detail: event.detail}));
return super.dispatchEvent(event as Event);
}
}

return TypedEventTarget;
}

class SomeTargetEvent extends typedEventTargetFactory<{ myEvent: { flag: boolean } }>() {}

const someTargetEvent = new SomeTargetEvent();

someTargetEvent.addEventListener("myEvent", (event) => event.detail.flag); // OK

someTargetEvent.addEventListener("all", (event) => event.detail.flag); // OK

someTargetEvent.dispatchEvent(new SomeTargetEvent.TypedEvent("myEvent", {detail: {flag: true}})); // OK

someTargetEvent.addEventListener("myEvent11111", null); // Argument of type "myEvent11111" is not assignable to parameter of type "all" | "myEvent"

someTargetEvent.addEventListener("myEvent", (event) => event.detail.noFlag); // Property noFlag does not exist on type { flag: boolean; }

someTargetEvent.dispatchEvent(new SomeTargetEvent.TypedEvent("myEvent", {detail: {noFlag: true}})); // Type { noFlag: true; } is not assignable to type { flag: boolean; }

1 ответов

79 просмотров

ок я понял теперь о чём ты

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта