最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - How to access Enum in typescript ? giving error "Element implicitly has an any type because index expressi

programmeradmin8浏览0评论
export enum r {
  color1 = "Red"
  color2 = "green"
  color3 = "blue"
}

ar = ["color1", "color2"];
ar.map(e => {
  if (r[e as any] !== undefined) {
    return r[e]
  }
})

Above statement giving "Element implicitly has an any type because index expression is not of type number"

export enum r {
  color1 = "Red"
  color2 = "green"
  color3 = "blue"
}

ar = ["color1", "color2"];
ar.map(e => {
  if (r[e as any] !== undefined) {
    return r[e]
  }
})

Above statement giving "Element implicitly has an any type because index expression is not of type number"

Share Improve this question edited Jan 14, 2021 at 16:01 uminder 26.2k6 gold badges43 silver badges89 bronze badges asked Jan 14, 2021 at 15:47 user9485480user9485480 311 silver badge3 bronze badges
Add a ment  | 

2 Answers 2

Reset to default 7

You need to type ar with keyof typeof to let TypeScript know your array contains keys from your enum:

export enum r {
  color1 = "Red",
  color2 = "green",
  color3 = "blue",
}

const ar: (keyof typeof r)[] = ["color1", "color2"];
const newVal = ar.map((e) => {
  if (r[e] !== undefined) {
    return r[e];
  }
});

Here is a good in-depth answer about it

You do not have mas after every item in your enum. However, the following is how you can typecast the argument to be type of key of the enum:

export enum r {
color1 = "Red",
color2 = "green",
color3 = "blue",
}

const ar = ["color1","color2"];
const new_ar = ar.filter(e => {
    if (e in r && r[e as keyof typeof r]) 
    {return true;}
    else {return false;}
})

The problem with your approach is you are using map and you need to return in every iteration. What you need is filter.

与本文相关的文章

发布评论

评论列表(0)

  1. 暂无评论