首頁  >  文章  >  web前端  >  利用JavaScript 判斷該物件是否為陣列

利用JavaScript 判斷該物件是否為陣列

怪我咯
怪我咯原創
2017-04-08 10:26:081232瀏覽

1. typeof

首先我們會想到的是使用typeof來偵測資料型別,但是對於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

但是對於陣列或正規來說,使用typeof來偵測的話,那就滿足不了,因為當我們偵測到陣列或正規的話,那麼傳回的類型將會是一個物件object,如下程式碼所示:

console.log(typeof []);  // object
console.log(typeof /\d+/g); // object

2. Instanceof

由此我們很容易會想到使用instanceof來偵測某個物件是否是陣列的實例,該偵測會傳回一個布林型(boolean),如果是陣列的話,傳回true,否則的話回傳false;我們再來看下上面的偵測是否為陣列的程式碼如下:

console.log([] instanceof Array);  // true
console.log(/\d+/g instanceof Array); // false

如上可以看到使用instanceof確實可以判斷是否為陣列的列子;

#3. constructor屬性

javascript中,每個物件都有一個constructor屬性,它引用了初始化該物件的建構子,例如判斷未知物件的類型,因此我們可以如下寫一個方法,程式碼如下:

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

如上可以看到,透過呼叫isArray 方法也可以判斷是否為陣列的列子。

我們現在可以看到,對於第二點和第三點分別使用instanceof方法和constructor屬性貌似都可以來判斷是否為數組了,但是也有列外情況,比如在跨框架iframe的時候使用頁面中的陣列時,會失敗,因為在不同的框架iframe中,創建的數組是不會相互共享其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下是不支持的,标准浏览器firefox,chrome下有

console.log(arr);  // 打印出 ["1", "2", "3", "4", "5"]
console.log(arr instanceof Array); // false 
console.log(arr.constructor === Array); // false

如上的方法我們都不能來判斷一個物件是否為數組的方式; 但是我們在看ECMA262中可以看到,可以使用Object.prototype.toString.call()方法來判斷一個物件是否為數組;如下程式碼:

function isArray(obj) {
    return Object.prototype.toString.call(obj) == '[object Array]';
}
// 代码调用
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


以上是利用JavaScript 判斷該物件是否為陣列的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn