TypeScript基础篇 --- 内置对象

内置对象

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

ECMAScript的内置对象

ECMAScript标准提供的内置对象有:
BooleanErrorDateRegExp等。
我们可以是 TypeScript中将变量定义为这些类型:

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

更多的内置对象可以查看MDN的文件,而他们的定义文件,则在TypeScript 核心库的定义文件中。

DOM和BOM的内置对象

DOM 和 BOM提供的内置对象有:DocumentHTMLElementEventNodeList等。
TypeScript中会经常用到这些类型:

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

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

TypeScript核心库的定义文件

TypeScript核心库的定义文件中定义了所有浏览器环境需要用到的类型,并且是预置在 TypeScript中的。
当你在使用一些常用的方法的时候, TypeScript市级上已经帮你做了很多类型判断工作了。

    Math.pow(10,'2') // 类型“"2"”的参数不能赋给类型“number”的参数

上面的李忠,Math.pow必须接受两个number类型的参数。事实上,Math.pow的定义是:

    interface Math{
        pow(x:number,y:number):number
    }

再举一个Dom的例子

    document.addEventListener('click',function(e){
        console.log(e.targetCurrent) // 类型“MouseEvent”上不存在属性“targetCurrent”。
    })

因为e被推断成了MouseEvent,而MouseEvent是没有targetCurrent属性的,所以报错了。
注意,TypeScript核心库的定义中不包含Node.js部分。

用 TypeScript写Node.js

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

    npm install @types/node --save-dev
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值