首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么这个键不能正确推断?

为什么这个键不能正确推断?
EN

Stack Overflow用户
提问于 2022-02-06 17:31:49
回答 1查看 25关注 0票数 0

我有这样的代码(TS游乐场):

代码语言:javascript
复制
const createComp = <T extends {
  modifiers:  {
    [key: string]: string;
  };
  defaultMods: keyof T["modifiers"];
}
>(com: T) => com;

const style = createComp({
  modifiers: {
    blue: 'blue',
    red: 'red'
  },
  defaultMods: 'red' // correct. defaultMods type is 'blue' | 'red'
});

正如我所期望的那样,它将defaultMods类型推断为'blue' | 'red'

但是,当我试图将extends类型提取为Component类型时,如下面(TS游乐场)所示:

代码语言:javascript
复制
type Component = {
  modifiers:  {
    [key: string]: string;
  };
  defaultMods: keyof Component["modifiers"];
}

const createComp = <T extends Component>(com: T) => com;

const style = createComp({
  modifiers: {
    blue: 'blue',
    red: 'red'
  },
  defaultMods: '' // defaultMods type is string
});

它不将defaultMods类型返回为'blue' | 'red'。我错过了什么吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-02-06 17:40:59

keyof Component["modifiers"]总是决定采用string。您将需要一个额外的Component类型参数来表示修饰符,并在您的函数中推断:

代码语言:javascript
复制
type Component<TModifiers extends Record<string, string>> = {
  modifiers: TModifiers;
  defaultMods: keyof TModifiers;
}


const createComp = <TModifiers extends Record<string, string>>(com: Component<TModifiers>) => com;


const style = createComp({
  modifiers: {
    blue: 'blue',
    red: 'red'
  },
  defaultMods: '' // it should be 'blue' | 'red'
});

操场连接

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

https://stackoverflow.com/questions/71009816

复制
相关文章

相似问题

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