色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

JavaScript 判斷該對象是否為數組

瀏覽:3日期:2023-11-19 09:59:15
1. typeof

首先我們會想到的是使用typeof來檢測數據類型,但是對于Function, String, Number, Undefined等這幾種基本類型來說,使用typeof來檢測都可以檢測到,比如代碼如下:

function test(){}console.log(typeof 1); // numberconsole.log(typeof test); // function console.log(typeof 'yunxi'); // stringconsole.log(typeof undefined); // undefined

但是對于數組或者正則來說,使用typeof來檢測的話,那就滿足不了,因為當我們檢測數組或者正則的話,那么返回的類型將會是一個對象object,如下代碼所示:

console.log(typeof []); // objectconsole.log(typeof /d+/g); // object2. Instanceof

由此我們很容易會想到使用instanceof來檢測某個對象是否是數組的實例,該檢測會返回一個布爾型(boolean),如果是數組的話,返回true,否則的話返回false;我們再來看下上面的檢測是否為數組的代碼如下:

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

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

3. constructor屬性

在javascript中,每個對象都有一個constructor屬性,它引用了初始化該對象的構造函數,比如判斷未知對象的類型,因此我們可以如下寫一個方法,代碼如下:

function isArray(obj) { return typeof obj == ’object’ && obj.constructor == Array}// 測試democonsole.log(isArray([])); // truevar a = {'a':1};console.log(isArray(a)); // falsevar b = [1,2,3];console.log(isArray(b)); // trueconsole.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([])); // trueconsole.log(isArray([1,2,3])); // truevar 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
相關文章:
主站蜘蛛池模板: 欧美国产合集在线视频 | 亚洲黄色免费观看 | 国产中文字幕免费观看 | 2019在线亚洲成年视频网站 | 九九九九在线视频播放 | 国产高清一级片 | 国产精品日韩欧美在线 | 欧美高清成人 | 国产综合在线视频 | 老师张开腿让我爽了一夜视频 | 亚洲qingse中文久久网 | 欧美一级做一级爱a做片性 欧美一欧美一级毛片 | 久国产| 成年大片免费视频播放手机不卡 | 人人草97| 国产成人综合网在线观看 | 国产高清视频在线 | 2022日韩理论片在线观看 | a级毛片免费高清视频 | 男女精品视频 | 亚洲欧美成人 | 久久久一区二区三区 | 人人草97| 九九热爱视频精品视频高清 | 91精品国产美女福到在线不卡 | 高清欧美一级在线观看 | 国产成人mv 在线播放 | 中文字幕欧美在线观看 | 在线看国产 | 亚洲精品日韩专区在线观看 | 看v片| 自拍偷自拍亚洲精品10p | 久久精品国内一区二区三区 | 亚洲人成网国产最新在线 | 日韩欧美理论 | 欧美日韩一区二区三区久久 | 97久久精品一区二区三区 | 亚洲精品第一区二区在线 | 免费中文字幕一级毛片 | 亚洲www.| 国产午夜精品免费一二区 |