JS中的类型检测
typeof操作符
typeof对于每一种基本类型都有不同的返回值,但是对于所有的引用类型都只返回'object'
注意:对于Null类型返回'object',对于特殊的引用类型Function返回'function'
Undefined类型: 'undefined'
Boolean类型: 'boolean'
String类型: 'string'
Number类型: 'number'
引用类型/Null类型: 'object'
Function类型: 'function'
instanceof操作符
instanceof 操作符用来判断左表达式的原型链里有没有右表达式的原型。
因此在一定情况下可以用来作为引用类型的检测方法。
比如,对于某个regexp实例a,利用instanceof来检测:a._proto_为RegExp.prototype;RegExp.prototype为RegExp.prototype,两个值相等,返回true
Javascript instanceof 运算符源码
function instance_of(L, R) {//L 表示左表达式,R 表示右表达式
var O = R.prototype;// 取 R 的显示原型
L = L.__proto__;// 取 L 的隐式原型
while (true) {
if (L === null)
return false;
if (O === L)// 这里重点:当 O 严格等于 L 时,返回 true
return true;
L = L.__proto__;
}
}
在利用instanceof来进行类型检测时,左表达式为检测对象,右表达式为需要检测的引用类型的构造函数
Object
Array
Function
Date
RegExp
Function
Global
Math
//以下为基本类型的显示构造函数,这些构造函数的实例不是基本类型。
Boolean
Number
String
注:Global对象是兜底的对象,所有全局变量和全局函数都是Global对象的属性,Global对象的属性有各种原生的构造函数,还有三个特殊值NaN,undefined,Infinity。 window对象是Global对象的浏览器实现,但是window对象包含更多的原生属性。
instanceof类型检测的缺点
instanceof的左右表达式必须满足在同个全局作用域中,因为不同全局作用域的构造函数的prototype属性不是同一个对象,比如在frame1中的Array.prototype与frame2中的Array.prototype就不是一个对象。
安全的类型检测方法
Object.protptype.toString.call(value)
在任何值上调用Object.prototype.toString,都会返回一个[object NativeConstructorName]的字符串。
比如:
var a = []
console.log(Object.prototype.toString.call(a)); //'[object Array]'
对于上文提到的所有类型以及JSON类型,这个方法都会返回不同的字符串(NativeConstructorName以大写字母开头),所以这是一个类型检测的好方法。