判断js数据类型的四种方法和原理

本文探讨了判断JavaScript数据类型的四种方法:typeof、instanceof、constructor和Object.prototype.toString。通过详细解析每种方法的工作原理,解释了它们在处理基本类型和引用类型时的差异,特别是对null和undefined的特殊处理,以及constructor的不稳定性。Object.prototype.toString方法被指出是最准确的数据类型判断方式。

怎么去判断一个数据属于哪个数据类型,这个是很常见的操作,我们一般都会想到typeof和instanceof这两个常见的方法,但有时候这两种方法并不能满足我们的需求。那让我们来看一下都有哪些可以判断数据类型的方法吧。

1.typeof
这个方法很常见,一般用来判断基本数据类型,如:string,number,boolean,symbol,bigint(es10新增一种基本数据类型bigint,详细介绍),undefined等。
typeof 目前能返回string,number,boolean,symbol,bigint,undefined,object,function这八种判断类型

   typeof '123'       string
   
   typeof 1           number
   
   typeof true        boolean
   
   typeof Symbol('1') symbol
   
   typeof 111n        bigint
   
   typeof undefined   undefined
   
   typeof null        object
   
   typeof {
   
   a:1,b:2}   object
   
   function c(){
   
   console.log('123')}
   
   typeof c          function
    

其实我一直有个疑问,null既然属于基本数据类型,为什么用typeof返回的是object呢?解答如下:
js 在底层存储变量的时候,会在变量的机器码的低位1-3位存储其类型信息
000:对象
010:浮点数
100:字符串
110:布尔
1:整数
但是对于 undefined 和 null 来说,这两个值的信息存储是有点特殊的。
null:所有机器码均为0
undefined:用 −2^30 整数来表示
所以,typeof 在判断 null 的时候就出现问题了,由于 null 的所有机器码均为0,因此直接被当做了对象来看待。

2.instanceof
一般用来判断引用数据类型,如:Object,Function,Array,Date,RegExp等

 /s/g instanceof RegExp    true
        
 new Date('2019/01/05') instanceof Date   true
        
 [1,2
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值