在我们初识javascript的是,对于类型的检测也许只知道typeof,或者说最常用的是typeof,但是并不是所有的类型检测都是用typeof,在javascript中对于类型的检测目前用到的有五种方法,他们分别是:typeof、hasOwnProperty、instanceof、Object.prototype.toString.apply()、constructor,下面我们就来说说他们的使用和区别:
typeof
typeof操作符返回一个字符串,表示未经求值的操作数的类型;
使用语法:
typeof 某变量
typeof特别适合一个函数对象和基本类型的判断,但是,要注意:有一个特殊的null,typeof null会返回一个Object为什么会返回一个object,null它表示空指针对象,其他的都会返回一个字符串,这个问题是因为javascript的历史原因,但是对于其他的来时typeof就不是一个很好的选择了
hasOwnProperty
在javascript中,hasOwnProPerty返回的是一个bool值,他是指一个对象有没有指定名称的属性;
使用语法:object.hasOwnProPerty(proName)
语法说明:object为某个对象,proName为指定名称的属性
instanceof
对于判断对象类型我们常用instanceof,instanceof是基于原型链去判断的一个操作符;
使用语法:Object instanceof Object;它是希望左操作数是一个对象,返回true,如果他不是一个对象,是一个基本类型的,比如说1,2,3,等他就会直接返回false,他希望右操作符必须是一个函数对象或者函数构造器,如果不是,就会直接抛出typeError异常,他的大概原理就是他会判断左操作数的这样一个对象的原型链上是否有右边这个构造函数的prototype属性;通俗的讲就是左操作数是否是右面的对象的实例
Object.prototype.toString.apply()
使用Object.prototype.toString.apply(),去判断数组,基本类型,函数等等,把要判断的传给apply()方法;
语法如下:
Object.prototype.toString.apply([]); // 结果是[object Array]
Object.prototype.toString.apply(function(){}); // 结果是[object Function]
Object.prototype.toString.apply(null); //结果是[object Null]
注意:在IE6/7/8中,Object.prototype.toString.apply(null)返回“[object Object]”,有兼容性问题出现
constructor
我们知道,每一个对象都有一个constructor属性,他是继承他的原型,由于constructor是可以改写原型的,所以使用的时候要万分小心,不建议使用;