数据类型的判断方法
typeof:
能准确判断除 null 以外的基本数据类型的值,
对于对象类型,除了函数会判断成 function,其他对象类型一律返回 object
补充:
为什么typeof null会判断为object?
不同的对象在底层都表示为二进制,在 JavaScript 中二进制前三位都为 0 的话会被判断为 object 类型, null 的二进制表示是全 0,自然前三位也是 0,所以执行 typeof 时会返回“ object ”。
这个bug是第一版Javascript留下来的。
instanceof:
(不能判断基本数据类型)
基础介绍:
运算符用于检测构造函数的 prototype
属性是否出现在某个实例对象的原型链上,返回值为布尔值,用于指示一个变量是否属于某个对象的实例。
进阶原理:
instanceof
主要的实现原理就是只要右边变量的 prototype
在左边变量的原型链上即可。因此,instanceof
在查找的过程中会遍历左边变量的原型链,直到找到右边变量的 prototype
,如果查找失败,则会返回 false
. 具体步骤如下:
-
获取左边变量的隐式原型(即:__ proto __ ,可通过 Object.getPrototypeOf()获取);
-
获取右边变量的显示原型(即:prototype);
-
进行判断,比较 leftVal. __ proto __ . __ proto __ …… === rightVal.prototype,相等则返回 true,否则返回 false。
补充:
上边的列子可以发现,当判断数组是否为对象时 会返回true,这就是instanceof存在的弊端,理解instanceof判断原理即可理解此原因,所以我们在判断是否为数组时,使用Array.isArray()判断
constructor:
优点:基本能检测所有的类型(除了 null 和 undefined)
缺点:constructor易被 修改
Object.prototype.toString:
toString() 是 Object 的原型方法,调用该方法,可以统一返回格式为 “[object Xxx]” 的字符串,其中 Xxx 就是对象的类型。
对于 Object 对象,直接调用 toString() 就能返回 [object Object];
对于其他类型,则需要通过 call 来调用(改变this的指向,让()调用Object.prototype.toString方法),才能返回正确的类型信息。
优点:检测出所有类型