字串字面量型別

字串字面量 (String Literal) 型別用來約束取值只能是某幾個字串中的一個。

簡單的例子

type EventNames = 'click' | 'scroll' | 'mousemove';
function handleEvent(ele: Element, event: EventNames) {
    // do something
}

handleEvent(document.getElementById('hello'), 'scroll');  // 沒問題
handleEvent(document.getElementById('world'), 'dbclick'); // 報錯,event 不能為 'dbclick'

// index.ts(7,47): error TS2345: Argument of type '"dbclick"' is not assignable to parameter of type 'EventNames'.

上例中,我們使用 type 定了一個字串字面量型別 EventNames,它只能取三種字串中的一種。

注意,型別別名與字串字面量型別都是使用 type 進行定義。

參考

Last updated