JavaScript 判断对象类型的方法 (typeof,instanceof)

  • Post author:
  • Post category:java


typeof 只能检查出来以上7几种类型

Undefined “undefined”

Null “object” (见下方)

布尔值 “boolean”

数值 “number”

字符串 “string”

Symbol (ECMAScript 6 新增) “symbol”

宿主对象(JS环境提供的,比如浏览器) Implementation-dependent

函数对象 (implements [[Call]] in ECMA-262 terms) “function”

任何其他对象 “object”

instanceof 又叫关系运算符,可以用来判断某个构造函数的prototype属性是否存在另外一个要检测对象的原型链上,判断是否为该对象的实例

[] instanceof Array; // true

[] instanceof Object; // true

[] instanceof RegExp; // false

new Date instanceof Date; // true

constructor 属性。 JavaScript中,每个对象都有一个constructor属性,它引用了初始化该对象的构造函数,常用于判断未知对象的类型。如给定一个求知的值 通过typeof运算符来判断它是原始的值还是对象。如果是对象,就可以使用constructor属性来判断其类型。所以判断数组的函数也可以这样写:

function isArray(arr){

return typeof arr == “object” && arr.constructor == Array;

}

很多情况下,我们可以使用instanceof运算符或对象的constructor属性来检测对象是否为数组。例如很多JavaScript框架就是使用这两种方法来判断对象是否为数组类型。 但是检测在跨框架(cross-frame)页面中的数组时,会失败。原因就是在不同框架(iframe)中创建的数组不会相互共享其prototype属性。例如:

<script>

window.οnlοad=function(){

var iframe_arr=new window.frames[0].Array;

alert(iframe_arr instanceof Array); // false

alert(iframe_arr.constructor == Array); // false

}

</script>

在Ajaxian上看到了一种精确的检测方法,跨原型链调用toString()方法:Object.prototype.toString()。可以解决上面的跨框架问题。 当Object.prototype.toString(o)执行后,会执行以下步骤: 1)获取对象o的class属性。 2)连接字符串:”[object “+结果(1)+”]” 3)返回 结果(2) 例如:

Object.prototype.toString.call([]); // 返回 “[object Array]”

Object.prototype.toString.call(/reg/ig); // 返回 “[object RegExp]”

这样,我们就可以写一个健壮的判断对象是否为数组的函数:

function isArray(arr){

return Object.prototype.toString.call(arr) === “[object Array]”;

}



版权声明:本文为fortunegrant原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。