首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在typescript中仅使用原始类型属性的一部分创建子类型

在typescript中仅使用原始类型属性的一部分创建子类型
EN

Stack Overflow用户
提问于 2021-11-04 08:00:27
回答 1查看 31关注 0票数 0

我有以下typescript定义:

代码语言:javascript
复制
interface myType {
    A: {
      instance: someInstance,
      ...
    },
    B: {
      instance: someOtherInstance,
      ...
    }
}

我想创建一个类型,它接受myType接口的所有属性,并生成一个对象,该对象接受来自该接口的实例类型。大致是这样的:

代码语言:javascript
复制
type myBasicType<TType> = '...';

const a: myBasicType<myType> = {
   A: '...', // an instance of someInstance here
   B: '...', // an instance of someOtherInstance here
}

基本上,我需要的是一个功能,它生成一个基于接口的类型,其中原始接口的属性保持不变,但它们的类型根据原始接口的特定属性更改为新类型。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-11-04 08:11:05

您可以使用mapped types

代码语言:javascript
复制
class someInstance {
  tag: 'someInstance' = 'someInstance'
}

class someOtherInstance {
  tag: 'someOtherInstance' = 'someOtherInstance'
}

interface myType {
  A: {
    instance: someInstance,
  },
  B: {
    instance: someOtherInstance,
  }
}

type Mapper<T> = {
  [Prop in keyof T]: T[Prop] extends { instance: unknown } ? T[Prop]['instance'] : never
}

// type Result = {
//     A: someInstance;
//     B: someOtherInstance;
// }
type Result = Mapper<myType>

Playground

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

https://stackoverflow.com/questions/69835956

复制
相关文章

相似问题

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