js判斷一個對象爲數組的方法

數組對象

js的數組是無類型的:數組元素可以是任意類型,並且同一個數組中的不同元素也可能有不同的類型。數組的元素可以是對象或其他數組,這樣就可以創建複雜的數據結構。
通常我們可以用一元運算符typeof來判斷js的數據類型,但是對於數組這樣一個特殊的對象卻只能返回"object"
typeof [1,2,3]
"object"
typeof 100
"number"
typeof false
"boolean"
typeof undefined
"undefined"
typeof NaN
"number"
typeof function(){}
"function"
typeof null
"object"

判斷數組的方法

  • instanceof
    instanceof 是一個二元運算符,左邊操作數是一個對象,不是的話返回false,右邊操作數是一個函數對象或者函數構造器,不是的話返回false。原理是通過判斷左操作數的對象的原型鏈上是否具有右操作數的構造函數的prototype屬性。
[1,2] instanceof Array 
true
  • Array.isArray(arr)
    這個ES5新增的一個Array方法,該方法是Array對象的一個靜態函數,用來判斷一個對象是不是數組。
Array.isArray([1,2])
true
如果頁面裏面有n個frame,就存在多個window,每個window都有自己的Array對象,比如確定子window裏的某個數組是不是Array時,用instanceof這個方法就不行了
var fr=window.frames[0];
fr.οnlοad=function(){
   console.log(fr.arr instanceof Array);//false
   console.log(Array.isArray(fr.arr));//true
   //arr是另外一個頁面的一個數組
}
  • Object.prototype.toString.call(arr) === “[object Array]”
Object.prototype.toString.call([1,2])
"[object Array]"
  • arr.constructor.name===’Array’
[1,2].constructor.name==='Array';
true
但是對象的constructor屬性可以被改寫,改寫後用改方法判斷就不行了

var arr=[1,2];
arr.constructor={};
arr.constructor.name === "Array"  //undefined
false
  • 其他方法 可以通過數組的一些獨有的方法判斷該對象是不是數組,比如join,push等
var c=[1,2];
c.push('3');//3
console.log(c)
[1, 2, "3"]

var c="12";
c.push('3');
//Uncaught TypeError: c.push is not a function(…)


var c=[1,2];
c.join('');
"12"

var c='12';
c.join('');
//Uncaught TypeError: c.join is not a function(…)

總結

通過上面的幾種判斷對象爲數組對象的方法分析,使用Array.isArray(arr)和Oblect.prototype.toString.call(arr)是比較好的方法。

發佈了29 篇原創文章 · 獲贊 78 · 訪問量 11萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章