js判断复合数据类型的两种方式(typeof不奏效了)

作者:zccst

typeof认为所有的复合数据类型都是"object",没法进一步细分,所以还得用其他方法

先上结论:

1,(arr && typeof(arr) === "object" && arr.constructor === Array)

2,Object.prototype.toString.call(arr);

Js代码  技术分享
  1. Object.prototype.toString.call([]);  
  2. //"[object Array]"  
  3. Object.prototype.toString.call({});  
  4. //"[object Object]"  



例子:

Js代码  技术分享
  1. var arr = [];  
  2. arr[‘name‘] = "helios";  
  3. arr[‘version‘] = ‘trunk‘;  
  4. console.log(arr, typeof arr);  
  5. console.dir(arr);//信息比较全面  
  6. $.each(arr, function(key, item){//没有进入循环,是因为length=0  
  7.     console.log(key, item, item[key]);  
  8. });  
  9. console.log( Object.prototype.toString.call(arr) );  
  10. console.log( arr.constructor , arr.constructor === Array);  
  11. console.log(arr && typeof(arr) === "object" && arr.constructor === Array);  



打印:
[name: "helios", version: "trunk"] "object"
Array[0]
  length: 0
  name: "helios"
  version: "trunk"
  __proto__: Array[0]
[object Array]
function Array() { [native code] } true
true

批注:
1,arr还是数组。只不过length=0,同时绑定了两个静态变量。jQuery不循环这类数据。

2,typeof只是用来判断基本数据类型的。复合数据类型typeof判断出都是"object"

3,instanceof也不奏效,因为他们是继承关系。

Js代码  技术分享
    1. var arr = [];  
    2. arr[‘name‘] = "helios";  
    3. arr[‘version‘] = ‘trunk‘;  
    4. console.log( arr instanceof Array );  //true  
    5. console.log( arr instanceof Object ); //true 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。