您现在的位置是:首页 > 编程 > 

【TypeScript】009

2025-07-24 03:16:41
【TypeScript】009 10、内置对象 JavaScript 中有很多内置对象,它们可以直接在 TypeScript 中当做定义好了的类型。 内置对象是指根据标准在全局作用域(Global)上存在的对象。这里的标准是指 ECMAScript 和其他环境(比如 DOM)的标准。ECMAScript 的内置对象ECMAScript 标准提供的内置对象有:Boolean、Error、Date、

【TypeScript】009

10、内置对象

JavaScript 中有很多内置对象,它们可以直接在 TypeScript 中当做定义好了的类型。 内置对象是指根据标准在全局作用域(Global)上存在的对象。这里的标准是指 ECMAScript 和其他环境(比如 DOM)的标准。

ECMAScript 的内置对象

ECMAScript 标准提供的内置对象有:

BooleanErrorDateRegExp 等。

我们可以在 TypeScript 中将变量定义为这些类型:

代码语言:javascript代码运行次数:0运行复制
let b: Boolean = new Boolean(1);
let e: Error = new Error('Error occurred');
let d: Date = new Date();
let r: RegExp = /[a-z]/;

更多的内置对象,可以查看 MD 的文档。

而他们的定义文件,则在 TypeScript 核心库的定义文件中。

DOM 和 BOM 的内置对象

DOM 和 BOM 提供的内置对象有:

DocumentHTMLElementEventodeList 等。

TypeScript 中会经常用到这些类型:

代码语言:javascript代码运行次数:0运行复制
let body: HTMLElement = document.body;
let allDiv: odeList = document.querySelectorAll('div');
document.addEventListener('click', function(e: MouseEvent) {
  // Do something
});

它们的定义文件同样在 TypeScript 核心库的定义文件中。

TypeScript 核心库的定义文件

TypeScript 核心库的定义文件中定义了所有浏览器环境需要用到的类型,并且是预置在 TypeScript 中的。

当你在使用一些常用的方法的时候,TypeScript 实际上已经帮你做了很多类型判断的工作了,比如:

代码语言:javascript代码运行次数:0运行复制
Math.pow(10, '2');

// (1,14): error TS245: Argument of type 'string' is not assignable to parameter of type 'number'.

上面的例子中,Math.pow 必须接受两个 number 类型的参数。事实上 Math.pow 的类型定义如下:

代码语言:javascript代码运行次数:0运行复制
interface Math {
    /**
     * Returns the value of a base expression taken to a specified power.
     * @param x The base value of the expression.
     * @param y The exponent value of the expression.
     */
    pow(x: number, y: number): number;
}

再举一个 DOM 中的例子:

代码语言:javascript代码运行次数:0运行复制
document.addEventListener('click', function(e) {
    cole.log();
});

// (2,17): error TS29: Property 'targetCurrent' does not exist on type 'MouseEvent'.

上面的例子中,addEventListener 方法是在 TypeScript 核心库中定义的:

代码语言:javascript代码运行次数:0运行复制
interface Document extends ode, GlobalEventHandlers, odeSelector, DocumentEvent {
    addEventListener(type: string, listener: (ev: MouseEvent) => any, useCapture?: boolean): void;
}

所以 e 被推断成了 MouseEvent,而 MouseEvent 是没有 targetCurrent 属性的,所以报错了。

注意,TypeScript 核心库的定义中不包含 ode.js 部分。

用 TypeScript 写 ode.js

ode.js 不是内置对象的一部分,如果想用 TypeScript 写 ode.js,则需要引入第三方声明文件:

代码语言:javascript代码运行次数:0运行复制
npm install @types/node --save-dev

参考内置对象:

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。 原始发表:2025-01-06,如有侵权请联系 cloudcommunity@tencent 删除浏览器作用域typescript变量对象

#感谢您对电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格的认可,转载请说明来源于"电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格

本文地址:http://www.dnpztj.cn/biancheng/1197010.html

相关标签:无
上传时间: 2025-07-23 08:31:26
留言与评论(共有 9 条评论)
本站网友 工程院院士增选
1分钟前 发表
TypeScript 核心库的定义文件TypeScript 核心库的定义文件中定义了所有浏览器环境需要用到的类型
本站网友 白开水中毒
12分钟前 发表
内置对象是指根据标准在全局作用域(Global)上存在的对象
本站网友 cao1234
4分钟前 发表
TypeScript 核心库的定义文件TypeScript 核心库的定义文件中定义了所有浏览器环境需要用到的类型
本站网友 朱新礼
9分钟前 发表
'2'); // (1
本站网友 海安二手房信息
28分钟前 发表
boolean)
本站网友 javaqq
1分钟前 发表
MouseEvent) { // Do something });它们的定义文件同样在 TypeScript 核心库的定义文件中
本站网友 特殊字体
1分钟前 发表
Date
本站网友 苏州搜房网地图
10分钟前 发表
则需要引入第三方声明文件:代码语言:javascript代码运行次数:0运行复制npm install @types/node --save-dev 参考内置对象:本文参与 腾讯云自媒体同步曝光计划