繁体   English   中英

我可以定义一个带有计算键的 Typescript 接口吗?

[英]Can I define a Typescript interface with computed keys?

我想定义一个带有计算键的 Typescript 接口:

const NAMESPACE = 'com.pizza'

const KEY_SAUCE = `${NAMESPACE}/sauce`
const KEY_CRUST = `${NAMESPACE}/crust`

interface PizzaToken {
  radius:      number
  [KEY_SAUCE]: Sauce
  [KEY_CRUST]: Crust
}

const pizza: PizzaToken = PizzaFactory.getToken(...)
console.log(pizza[KEY_SAUCE])

这种设计模式给了我两个不相关的 Typescript 错误; 首先,在界面上:

TS1169: A computed property name in an interface must refer to an 
expression whose type is a literal type or a 'unique symbol' type.

第二个是pizza[KEY_SAUCE]

TS7053: Element implicitly has an 'any' type because expression of 
type 'any' can't be used to index type 'Pizza'.

我可以通过一些变通方法(例如Symbol )解决这些问题,但它们有点笨拙。 制作这样的作品的最佳方法是什么?

您需要使用as const在键声明处创建非扩展字符串文字类型:

const KEY_SAUCE = `${NAMESPACE}/sauce` as const;
const KEY_CRUST = `${NAMESPACE}/crust` as const;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM