typeof 在TypeScript中和JavaScript中的区别

前言        

        在TypeScript中和JavaScript中都有typeOf,但是作用用法却大有不同。

js的typeof

一、typeof用来判断数据类型返回结果:

基本数据类型:string,number,boolean,undefined
引用数据类型:object (不管是什么引用类型就返回object),function

二、typeof判断变量是否存在

typeof a!="undefined"

ts的typeof

        ts中的typeof可以根据已有的值在函数中有默认变量的值,获取该值的类型,简化类型书写

        ts中的typeof不仅可以获取数据的类型,还可以在类型上下文中引用变量和属性的类型(类型查询)。

        注意只能查询变量,不能查询函数调用的。

function add(point: { x: number; y: number }) {}
const p = {x:1,y:2}
add(p)

        一般我们都是这样子写 。但是有了typeof我们可以直接声明p,实现弯道超车

const p = {x:1,y:2}
function add(point: typeof p) {}
add(p)

         add函数会根据p的类型限制以后的入参。

        当然了ts的typeof也可以跟js一样,对类型进行验证限制,也就是TS说的类型守护

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值