JavaScript判斷對象是否為數(shù)組
文中為大家分享了三種JavaScript判斷對象是否為數(shù)組的方法,
1. typeof
首先我們會想到的是使用typeof來檢測數(shù)據(jù)類型,但是對于Function, String, Number, Undefined等這幾種基本類型來說,使用typeof來檢測都可以檢測到,比如代碼如下:
function test(){}
console.log(typeof 1); // number
console.log(typeof test); // function
console.log(typeof "yunxi"); // string
console.log(typeof undefined); // undefined
但是對于數(shù)組或者正則來說,使用typeof來檢測的話,那就滿足不了,因為當(dāng)我們檢測數(shù)組或者正則的話,那么返回的類型將會是一個對象object,如下代碼所示:
console.log(typeof []); // object console.log(typeof /\d+/g); // object
2. Instanceof
由此我們很容易會想到使用instanceof來檢測某個對象是否是數(shù)組的實例,該檢測會返回一個布爾型(boolean),如果是數(shù)組的話,返回true,否則的話返回false;我們再來看下上面的檢測是否為數(shù)組的代碼如下:
console.log([] instanceof Array); // true console.log(/\d+/g instanceof Array); // false
如上可以看到使用instanceof確實可以判斷是否為數(shù)組的列子;
3. constructor屬性
在javascript中,每個對象都有一個constructor屬性,它引用了初始化該對象的構(gòu)造函數(shù),比如判斷未知對象的類型,因此我們可以如下寫一個方法,代碼如下:
function isArray(obj) {
return typeof obj == 'object' && obj.constructor == Array
}
// 測試demo
console.log(isArray([])); // true
var a = {"a":1};
console.log(isArray(a)); // false
var b = [1,2,3];
console.log(isArray(b)); // true
console.log(isArray(/\d+/g));// false
如上可以看到,通過調(diào)用isArray 方法也可以判斷是否為數(shù)組的列子。
我們現(xiàn)在可以看到,對于第二點和第三點分別使用instanceof方法和constructor屬性貌似都可以來判斷是否為數(shù)組了,但是也有列外情況,比如在跨框架iframe的時候使用頁面中的數(shù)組時,會失敗,因為在不同的框架iframe中,創(chuàng)建的數(shù)組是不會相互共享其prototype屬性的;如下代碼測試即可得到驗證~
var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
xArray = window.frames[window.frames.length-1].Array;
var arr = new xArray("1","2","3","4","5");
//這個寫法IE下是不支持的,標(biāo)準(zhǔn)瀏覽器firefox,chrome下有
console.log(arr); // 打印出 ["1", "2", "3", "4", "5"]
console.log(arr instanceof Array); // false
console.log(arr.constructor === Array); // false
如上的方法我們都不能來判斷一個對象是否為數(shù)組的方式; 但是我們在看ECMA262中可以看到,可以使用 Object.prototype.toString.call()方法來判斷一個對象是否為數(shù)組;如下代碼:
function isArray(obj) {
return Object.prototype.toString.call(obj) == '[object Array]';
}
// 代碼調(diào)用
console.log(isArray([])); // true
console.log(isArray([1,2,3])); // true
var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
xArray = window.frames[window.frames.length-1].Array;
var arr = new xArray("1","2","3","4","5");
console.log(arr); // ["1","2","3","4","5"]
console.log(isArray(arr)); // true
以上就是本文的全部內(nèi)容,幫助大家學(xué)習(xí)JavaScript判斷對象是否為數(shù)組的方法,希望對大家的學(xué)習(xí)有所幫助。
- Javascript中判斷變量是數(shù)組還是對象(array還是object)
- js實現(xiàn)數(shù)組去重、判斷數(shù)組以及對象中的內(nèi)容是否相同
- js語法學(xué)習(xí)之判斷一個對象是否為數(shù)組
- JS判斷兩個數(shù)組或?qū)ο笫欠裣嗤姆椒ㄊ纠?/a>
- javascript 判斷一個對象為數(shù)組的方法
- javascript判斷一個變量是數(shù)組還是對象
- JavaScript判斷變量是對象還是數(shù)組的方法
- JavaScript判斷對象和數(shù)組的兩種方法
- JavaScript中判斷變量是數(shù)組、函數(shù)或是對象類型的方法
- js判斷一個對象是數(shù)組(函數(shù))的方法實例
相關(guān)文章
基于iscroll.js實現(xiàn)下拉刷新和上拉加載效果
這篇文章主要為大家詳細(xì)介紹了基于iscroll.js實現(xiàn)下拉刷新和上拉加載效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11
使用focus方法讓光標(biāo)默認(rèn)停留在INPUT框
讓光標(biāo)默認(rèn)停留在INPUT框中,用focus方法可以實現(xiàn),下面有個示例代碼,需要的朋友可以參考下2014-07-07
第九篇Bootstrap導(dǎo)航菜單創(chuàng)建步驟詳解
這篇文章主要介紹了Bootstrap導(dǎo)航菜單創(chuàng)建步驟詳解的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-06-06
js 為label標(biāo)簽和div標(biāo)簽賦值的方法
這篇文章介紹了js 為label標(biāo)簽和div標(biāo)簽賦值的方法,有需要的朋友可以參考一下2013-08-08
UniApp使用vue.config.js進(jìn)行配置的詳細(xì)教程
這篇文章主要給大家介紹了關(guān)于UniApp使用vue.config.js進(jìn)行配置的詳細(xì)教程,uniapp是一套基于Vue語法的框架,同樣也支持Vue.config.js配置,一般常用的莫過于路徑的名稱,需要的朋友可以參考下2023-10-10
詳解如何用webpack打包一個網(wǎng)站應(yīng)用項目
本篇文章主要介紹了如何用webpack打包一個網(wǎng)站應(yīng)用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07
Javascript中setTimeOut和setInterval的定時器用法
這篇文章主要介紹了Javascript中setTimeOut和setInterval的定時器用法的相關(guān)資料,需要的朋友可以參考下2015-06-06

