簡體   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