javascript 判斷一個對象為數(shù)組的方法
javascript 判斷一個對象為數(shù)組的方法
數(shù)組對象
js的數(shù)組是無類型的:數(shù)組元素可以是任意類型,并且同一個數(shù)組中的不同元素也可能有不同的類型。數(shù)組的元素可以是對象或其他數(shù)組,這樣就可以創(chuàng)建復(fù)雜的數(shù)據(jù)結(jié)構(gòu)。
通常我們可以用一元運(yùn)算符typeof來判斷js的數(shù)據(jù)類型,但是對于數(shù)組這樣一個特殊的對象卻只能返回"object"
typeof [1,2,3]
"object"
typeof 100
"number"
typeof false
"boolean"
typeof undefined
"undefined"
typeof NaN
"number"
typeof function(){}
"function"
typeof null
"object"
判斷數(shù)組的方法
instanceof
instanceof 是一個二元運(yùn)算符,左邊操作數(shù)是一個對象,不是的話返回false,右邊操作數(shù)是一個函數(shù)對象或者函數(shù)構(gòu)造器,不是的話返回false。原理是通過判斷左操作數(shù)的對象的原型鏈上是否具有右操作數(shù)的構(gòu)造函數(shù)的prototype屬性。
[1,2] instanceof Array true
Array.isArray(arr)
這個ES5新增的一個Array方法,該方法是Array對象的一個靜態(tài)函數(shù),用來判斷一個對象是不是數(shù)組。
Array.isArray([1,2]) true
如果頁面里面有n個frame,就存在多個window,每個window都有自己的Array對象,比如確定子window里的某個數(shù)組是不是Array時,用instanceof這個方法就不行了
var fr=window.frames[0];
fr.onload=function(){
console.log(fr.arr instanceof Array);//false
console.log(Array.isArray(fr.arr));//true
//arr是另外一個頁面的一個數(shù)組
}
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其他方法 可以通過數(shù)組的一些獨有的方法判斷該對象是不是數(shù)組,比如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(…)
總結(jié)
通過上面的幾種判斷對象為數(shù)組對象的方法分析,使用Array.isArray(arr)和Oblect.prototype.toString.call(arr)是比較好的方法。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
JavaScript實現(xiàn)動畫打開半透明提示層的方法
這篇文章主要介紹了JavaScript實現(xiàn)動畫打開半透明提示層的方法,涉及javascript操作DOM的相關(guān)技巧,非常具有實用價值,需要的朋友可以參考下2015-04-04
JS實現(xiàn)Excel導(dǎo)出功能以及導(dǎo)出亂碼問題解決詳解
這篇文章主要為大家詳細(xì)介紹了JavaScript如何調(diào)用后臺接口實現(xiàn)Excel導(dǎo)出功能以及導(dǎo)出亂碼問題的解決辦法,需要的小伙伴可以參考一下2023-07-07
javascript實現(xiàn)驗證IP地址等相關(guān)信息代碼
本文給大家分享的是一組判斷IP地址是否合法,判斷子網(wǎng)掩碼是否合法,驗證輸入的網(wǎng)關(guān)地址是否合法的javascript代碼,十分的簡單實用,有需要的小伙伴可以參考下。2015-05-05
JavaScript對象與JSON格式的轉(zhuǎn)換及JSON.stringify和JSON.parse的使用方法
這篇文章主要介紹了JavaScript對象與JSON格式的轉(zhuǎn)換及JSON.stringify和JSON.parse的使用方法,JSON是JavaScript表達(dá)值和對象的通用數(shù)據(jù)格式,其本質(zhì)就是符合一定規(guī)范的字符串2022-07-07
js實現(xiàn)小球在頁面規(guī)定的區(qū)域運(yùn)動
這篇文章主要為大家詳細(xì)介紹了js控制小球在規(guī)定范圍運(yùn)動,碰到邊界就改變運(yùn)動方向,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-06-06
Firefox下設(shè)為主頁的JavaScript代碼
在IE下,我們可以輕松使用以下代碼來實現(xiàn)設(shè)置主頁 但在firefox我們需要做的更多2008-09-09
一文學(xué)會JavaScript如何手寫防抖節(jié)流
其實防抖和節(jié)流不僅僅在面試中會讓大家手寫,在實際項目中也可以起到性能優(yōu)化的作用,所以還是很有必要掌握的。這篇文章就帶大家徹底學(xué)會JavaScript手寫防抖節(jié)流,希望對大家有所幫助2022-11-11

