【发布时间】:2017-08-12 08:15:31
【问题描述】:
我目前正在尝试改进一些现有代码的类型。我的代码大致是这样的:
/* dispatcher.ts */
interface Message {
messageType: string;
}
class Dispatcher<M extends Message> {
on<
MessageType extends M["messageType"],
SubMessage extends M & { messageType: MessageType }
>(
messageType: MessageType,
handler: (message: SubMessage) => void
): void { }
}
/* messages.ts */
interface AddCommentMessage {
messageType: "ADD_COMMENT";
commentId: number;
comment: string;
userId: number;
}
interface PostPictureMessage {
messageType: "POST_PICTURE";
pictureId: number;
userId: number;
}
type AppMessage = AddCommentMessage | PostPictureMessage;
/* app.ts */
const dispatcher = new Dispatcher<AppMessage>();
dispatcher.on("ADD_COMMENT", (message: AddCommentMessage ) => {
/* ^^ REMOVE THIS TYPE HINT!*/
console.log(message.comment);
});
我想消除显式缩小传递给消息处理程序的消息类型(/*REMOVE THIS TYPE HINT!*/ 是)的需要,以便它正确地缩小到具有匹配 messageType 类型的类型(例如如果messageType 是"ADD_COMMENT" 那么message 应该是AddCommentMessage)。
如果现在无法做到这一点,请告诉我。我的印象是不是,但我不太确定。
【问题讨论】:
-
欢迎来到 Stack Overflow!请在问题本身的minimal reproducible example 中提供所有相关代码,而不仅仅是在第三方网站上。
标签: typescript type-inference inference narrowing