typescript - Typescript:将函数输入类型与 Array.reduce 函数中的输出类型匹配
问题描述
尝试通过 Array.reduce 函数生成对象时遇到问题。此代码将在 javascript 中正常工作。但是在打字稿中,我无法匹配 reduce 函数中的类型,它会引发如下所示的错误。
这是一个小例子,在我的例子中,有更多的输入类型和 2-3 级处理,比如下面的buildSchema函数。我宁愿通过 reduce 函数来生成它们,而不是像下面的morph对象那样手动列出它们。
知道如何通过类型系统解决这个问题吗?根据输入推断类型。所以我仍然可以拥有类型安全,但不必为不同的输入键一遍又一遍地复制粘贴相同的代码?
示例代码:
type inputs = "alpha" | "beta" | "gamma";
type AlphaSchema = {
pet: string,
house: string
}
type BetaSchema = {
boss: string,
work: string,
}
type GammaSchema = {
monk: string,
temple: string,
}
// Anything I can try using this type ? Using generics and keyof ?
// <T extends keyof Schemas> => Schemas[T] ?
type Schemas = {
'alpha': AlphaSchema,
'beta': BetaSchema,
'gamma': GammaSchema
}
type manualMorph = typeof morph
//////////////////////
const morphTypes : ["alpha", "beta", "gamma"] = ["alpha", "beta", "gamma"];
const buildSchema = {
'alpha' : (str1: string, str2: string): AlphaSchema => { return {pet: str1, house: str2} },
'beta' : (str1: string, str2: string): BetaSchema => { return {boss: str1, work: str2} },
'gamma' : (str1: string, str2: string): GammaSchema => { return {monk: str1, temple: str2} }
}
// Manually generated morph object
const morph = {
'alpha' : buildSchema['alpha'],
'beta' : buildSchema['beta'],
'gamma' : buildSchema['gamma'],
}
// Morph from reduce
const morphFromReduce: manualMorph = morphTypes.reduce((acc, type) => {
acc[type] = buildSchema[type];
return acc;
}, <manualMorph>{})
错误:
输入'((str1: string, str2: string) => AlphaSchema) | ((str1:字符串,str2:字符串)=> BetaSchema)| ((str1: string, str2: string) => GammaSchema)' 不能分配给类型 '((str1: string, str2: string) => AlphaSchema) & ((str1: string, str2: string) => BetaSchema) & ((str1: string, str2: string) => GammaSchema)'。
类型'(str1: string, str2: string) => AlphaSchema' 不可分配给类型 '((str1: string, str2: string) => AlphaSchema) & ((str1: string, str2: string) => BetaSchema) & ((str1: string, str2: string) => GammaSchema)'。
类型'(str1: string, str2: string) => AlphaSchema' 不可分配给类型 '(str1: string, str2: string) => BetaSchema'。
“AlphaSchema”类型缺少“BetaSchema”类型的以下属性:boss
我正在使用打字稿 4.1.3
解决方案
这将完成这项工作;)
const morphFromReduce = morphTypes.reduce(<T extends inputs>(acc: manualMorph, type: T) => {
acc[type] = buildSchema[type];
return acc;
}, {} as manualMorph);
推荐阅读
- php - 如何从数据库填充选择选项 - Spatie 权限包 - Laravel
- android - 任务 ':app:processDebugResources' 执行失败。反应原生
- elixir - 清空文件并永久存储状态
- python - 在Python中将json转换为coo稀疏矩阵
- python-3.x - 如何有效地从熊猫系列中提取(子)字符串
- python - 如何停止 Python 修改多个变量?
- c# - 在尊重 MVVM 的同时在 WPF 中使用 MediaEement
- java - 使用 Spring Security 启用 h2 控制台
- c# - 导出整个游戏后 UI 按钮没有响应
- javascript - 如何修复 TypeError?