五、typescript(内置对象)

本文介绍了如何在TypeScript中使用类型断言处理ES内置对象(如Boolean、Error等)、DOM和BOM对象,以及如何正确引用Math.pow和DOM事件处理函数,强调了类型安全的重要性。
摘要由CSDN通过智能技术生成

四、typscript(类型断言)-CSDN博客

5.1 ES 的内置对象(JS 中有很多内置对象,可以直接在 TS 中当做定义好了的类型)

// Boolean、Error、Date、RegExp 等

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

5.2 DOM 和 BOM 的内置对象

// Document、HTMLElement、Event、NodeList 等

let allDiv: NodeList = document.querySelectorAll('div');
document.addEventListener('click', function(e: MouseEvent) {
  // Do something
});

5.3 TS 核心库的定义文件

Math.pow(10, '2');
// 编译错误


因为 Math.pow 必须接受两个 number 参数,其类型定义如下:
interface Math {
    pow(x: number, y: number): number;
}


例2:
document.addEventListener('click', function(e) {
    console.log(e.targetCurrent);
});
// 编译错误

// addEventListener 在 TS 核心库的定义如下

interface Document extends Node, GlobalEventHandlers, NodeSelector, DocumentEvent {
    addEventListener(type: string, listener: (ev: MouseEvent) => any, useCapture?: boolean): void;
}
所以 e 被推断成了 MouseEvent,而 MouseEvent 是没有 targetCurrent 属性的,所以报错了(注意:TS 核心库的定义中不包含 Node.js 部分。)

  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值