首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >类型记录:基于键内容具有相同键和值的对象中的键列表

类型记录:基于键内容具有相同键和值的对象中的键列表
EN

Stack Overflow用户
提问于 2021-06-15 15:28:12
回答 1查看 539关注 0票数 0

我们需要键入函数,它需要一个键(字符串)列表,并生成具有相同键值的对象,当键以?开头或其他仅以?开头时,值为string

代码语言:javascript
复制
export function useParams<T extends string>(
  expected: T[]
): { [key in T as NonOptional<T>]: string } {
  // ... our custom implementation
  return null as any;
}

type NonOptional<T extends string> = T extends `?${infer Inner}` ? Inner : T;

// Should produce type { a: string; b: string | undefined }
const result = useParams(['a', '?b']);

但是,我不知道如何键入输出。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-06-15 16:28:12

您可以在元组的键上迭代它:

代码语言:javascript
复制
export function useParams<T extends readonly string[]>(
  expected: T
): { [K in T[number] as NonOptional<K>]: string | OrUndefined<K> } {
  return null as any;
}

type NonOptional<T extends string> = T extends `?${infer Inner}` ? Inner : T;
type OrUndefined<T extends string> = T extends `?${string}` ? undefined : never

const result = useParams(['a', '?b'] as const);

操场链接

增加了一节,以解决评论中所述的问题:

我很肯定开发人员会忘记添加作为const,然后它将停止正常工作。

要允许传递非只读元组,可以使用多元元组类型

代码语言:javascript
复制
export function useParams<T extends string[]>(
  expected: [...T]
): { [K in T[number] as NonOptional<K>]: string | OrUndefined<K> } {
  return null as any;
}

type NonOptional<T extends string> = T extends `?${infer Inner}` ? Inner : T;
type OrUndefined<T extends string> = T extends `?${string}` ? undefined : never

const result = useParams(['a', '?b']);

操场链接

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67989199

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档