查看数据类型:typeof、instanceof、Object.prototype.toString.call()、 constructor

本文介绍了JavaScript中查看数据类型的四种方法:typeof、instanceof、Object.prototype.toString.call()和constructor。typeof对于基本数据类型识别准确,但无法区分Array、Object和Null。instanceof适合判断自定义类实例,但不适用于Number、Boolean、String。Object.prototype.toString.call()提供精准的类型判断,但使用较繁琐。constructor可以用来判断数据类型和访问构造函数,但在原型链被修改时可能失效。
摘要由CSDN通过智能技术生成

查看数据类型

1.typeof

typeof 对于原始类型来说,除了 null 都可以显示正确的类型

typeof 1   //'number'

typeof '1'   //'string'

typeof undefined   //'undefined'

typeof true   //'boolean'

typeof Symbol()    //'symbol'
typeof [] // 'object'
typeof {
   } // 'object'
typeof console.log // 'function'

注意: 对于 null 来说,很多人会认为他是个对象类型,其实这是错误的。虽然 typeof null 会输出 object,但是这只是 JS 存在的一个悠久 Bug。在 JS 的最初版本中使用的是 32 位系统,为了性能考虑使用低位存储变量的类型信息,000 开头代表是对象,然而 null 表示为全零,所以将它错误的判断为 object 。虽然现在的内部类型

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值