【发布时间】:2021-02-14 10:18:13
【问题描述】:
不确定我追求的是什么打字稿功能,但我认为我需要一个通用的泛型(如果那是打字稿功能)。以下是我的要求。
我想表示一组事件/事件处理程序元组。以下是我目前所拥有的。
interface Event {
type: string;
}
type EventType<T extends Event> = T['type'];
type EventHandler<T extends Event> = (event:T): void;
// so far so good
type EventTypeAndHandlerTuple <T extends Event> = [EventType<T>, EventHandler<T>];
// this is where I wish I could do better. I am forced to used any
type EventTypeAndHandlerTuples = EventTypeAndHandlerTuple<any>[]
我希望能够表示这样的代码
const todoAddedEvent: TodoAddedEvent = {...}
const handleTodoAddedEvent: TodoAddedHandler = (event: TodoAddedEvent) => {...};
const todoRemovedEvent: TodoRemovedEvent = {...}
const handleTodoRemovedEvent: TodoRemovedHandler = (event: TodoRemovedEvent) => {...}
// HELP ME GIVE THIS THING A TYPE ????
const eventTypeToHandlerTuples = [
[todoAddedEvent, handleTodoAddedEvent],
[todoRemovedEvent, handleTodoRemovedEvent]
];
我想要一个eventTypeToHandlerTuples 的类型,如果它是关联事件类型和事件处理程序元组的集合,它就会通过。如果事件类型与不正确的处理程序相关联,我希望此类型表示失败。例如,我希望这失败
// this should fail because the removed event is being paired with the add event handler.
const eventTypeToHandlerTuples = [
[todoRemovedEvent, handleTodoAddedEvent],
];
在此先感谢您的意见
【问题讨论】:
标签: javascript typescript generics