內建物件

JavaScript 中有很多內建物件,它們可以直接在 TypeScript 中當做定義好了的型別。

內建物件是指根據標準在全域性作用域(Global)上存在的物件。這裡的標準是指 ECMAScript 和其他環境(比如 DOM)的標準。

ECMAScript 的內建物件

ECMAScript 標準提供的內建物件有:

BooleanErrorDateRegExp 等。

我們可以在 TypeScript 中將變數定義為這些型別:

let b: Boolean = new Boolean(1);
let e: Error = new Error('Error occurred');
let d: Date = new Date();
let r: RegExp = /[a-z]/;

更多的內建物件,可以檢視 MDN 的文件

而他們的定義檔案,則在 TypeScript 核心函式庫的定義檔案中。

DOM 和 BOM 的內建物件

DOM 和 BOM 提供的內建物件有:

DocumentHTMLElementEventNodeList 等。

TypeScript 中會經常用到這些型別:

它們的定義檔案同樣在 TypeScript 核心函式庫的定義檔案中。

TypeScript 核心函式庫的定義檔案

TypeScript 核心函式庫的定義檔案中定義了所有瀏覽器環境需要用到的型別,並且是預置在 TypeScript 中的。

當你在使用一些常用的方法的時候,TypeScript 實際上已經幫你做了很多型別判斷的工作了,比如:

上面的例子中,Math.pow 必須接受兩個 number 型別的引數。事實上 Math.pow 的型別定義如下:

再舉一個 DOM 中的例子:

上面的例子中,addEventListener 方法是在 TypeScript 核心函式庫中定義的:

所以 e 被推斷成了 MouseEvent,而 MouseEvent 是沒有 targetCurrent 屬性的,所以報錯了。

注意,TypeScript 核心函式庫的定義中不包含 Node.js 部分。

用 TypeScript 寫 Node.js

Node.js 不是內建物件的一部分,如果想用 TypeScript 寫 Node.js,則需要引入第三方宣告檔案:

參考

Last updated

Was this helpful?