JavaScript中如何判断变量是数组、函数还是对象类型

数组
  ECMAScript5中Array.isArray是原生的判断数组的方法,IE9及以上支持。考虑到兼容性,在没有此方法的浏览器中,可以使用Object.prototype.toString.call(obj) === '[object Array]'替代。

var isArray = Array.isArray || function(obj) {

    return Object.prototype.toString.call(obj) === '[object Array]';

}

函数
  最简单且性能最好的办法就是 typeof obj == 'function'。考虑到某些版本浏览器存在的bug,最靠谱的办法是 Object.prototype.toString.call(obj) === '[object Function]'。

var isFunction = function(obj) {

    return Object.prototype.toString.call(obj) === '[object Function]';

}

if(typeof /./ != 'function' && typeof Int8Array != 'object') {

    isFunction = function(obj) {

        return typeof obj == 'function';

    }

}

  注意:在IE678中,对于DOM对象的原生方法,无论是使用typeof还是Object.prototype.toString,都是返回object而不是function。这是因为在这些浏览器中,JScript引擎是单独实现的,没有集成到浏览器内核中。IE9以后JScript引擎进入了浏览器内核,此方法才能对DOM的原生方法正确识别。

对象
  在JavaScript中复杂类型是对象,函数也是对象。对上述2者使用typeof,可以分别得到'object’和'function'。另外,还要排除null值的情况,因为typeof null 得到的也是 'object'。

var isObject = function(obj) {

    var type = typeof obj;

    return type === 'function' || type === 'object' && !!obj;

}

 

你可能感兴趣的:(JavaScript)