91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JS如何判斷對象是不是數組

發布時間:2020-06-30 09:20:31 來源:億速云 閱讀:204 作者:清晨 欄目:開發技術

小編給大家分享一下JS如何判斷對象是不是數組,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討方法吧!

一、前言

如何判斷一個對象或一個值是否是一個數組,在面試或工作中我們常常會遇到這個問題,既然出現頻率高,想著還是做個整理,那么本文主要基于幾種判斷方式,以及方式判斷的原理,是否存在問題展開討論。

二、判斷對象是否是數組的幾種方式

1.通過instanceof判斷

instanceof運算符用于檢驗構造函數的prototype屬性是否出現在對象的原型鏈中的任何位置,返回一個布爾值。

let a = [];
a instanceof Array; //true
let b = {};
b instanceof Array; //false

在上方代碼中,instanceof運算符檢測Array.prototype屬性是否存在于變量a的原型鏈上,顯然a是一個數組,擁有Array.prototype屬性,所以為true。

存在問題:

需要注意的是,prototype屬性是可以修改的,所以并不是最初判斷為true就一定永遠為真。

其次,當我們的腳本擁有多個全局環境,例如html中擁有多個iframe對象,instanceof的驗證結果可能不會符合預期,例如:

//為body創建并添加一個iframe對象
var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
//取得iframe對象的構造數組方法
xArray = window.frames[0].Array;
//通過構造函數獲取一個實例
var arr = new xArray(1,2,3); 
arr instanceof Array;//false

導致這種問題是因為iframe會產生新的全局環境,它也會擁有自己的Array.prototype屬性,讓不同環境下的屬性相同很明顯是不安全的做法,所以Array.prototype !== window.frames[0].Array.prototype,想要arr instanceof Array為true,你得保證arr是由原始Array構造函數創建時才可行。

2.通過constructor判斷

我們知道,實例的構造函數屬性constructor指向構造函數,那么通過constructor屬性也可以判斷是否為一個數組。

let a = [1,3,4];
a.constructor === Array;//true

同樣,這種判斷也會存在多個全局環境的問題,導致的問題與instanceof相同。

//為body創建并添加一個iframe標簽
var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
//取得iframe對象的構造數組方法
xArray = window.frames[window.frames.length-1].Array;
//通過構造函數獲取一個實例
var arr = new xArray(1,2,3); 
arr.constructor === Array;//false

3.通過Object.prototype.toString.call()判斷

Object.prototype.toString().call()可以獲取到對象的不同類型,例如

let a = [1,2,3]
Object.prototype.toString.call(a) === '[object Array]';//true

它強大的地方在于不僅僅可以檢驗是否為數組,比如是否是一個函數,是否是數字等等

//檢驗是否是函數
let a = function () {};
Object.prototype.toString.call(a) === '[object Function]';//true
//檢驗是否是數字
let b = 1;
Object.prototype.toString.call(a) === '[object Number]';//true

甚至對于多全局環境時, Object.prototype.toString().call()也能符合預期處理判斷。

//為body創建并添加一個iframe標簽
var iframe = document.createElement('iframe');
document.body.appendChild(iframe);
//取得iframe對象的構造數組方法
xArray = window.frames[window.frames.length-1].Array;
//通過構造函數獲取一個實例
var arr = new xArray(1,2,3); 
console.log(Object.prototype.toString.call(arr) === '[object Array]');//true

4.通過Array.isArray()判斷

Array.isArray() 用于確定傳遞的值是否是一個數組,返回一個布爾值。

let a = [1,2,3]
Array.isArray(a);//true

簡單好用,而且對于多全局環境,Array.isArray() 同樣能準確判斷,但有個問題,Array.isArray() 是在ES5中提出,也就是說在ES5之前可能會存在不支持此方法的情況。怎么解決呢?

三、判斷數組方法的最終推薦

當然還是用Array.isArray(),從ES5新增isArray()方法正是為了提供一個穩定可用的數組判斷方法,不可能專門為此提出的好東西不用,而對于ES5之前不支持此方法的問題,我們其實可以做好兼容進行自行封裝,像這樣:

if (!Array.isArray) {
 Array.isArray = function(arg) {
  return Object.prototype.toString.call(arg) === '[object Array]';
 };
}

看完了這篇文章,相信你對JS如何判斷對象是不是數組有了一定的了解,想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

湘潭县| 孝昌县| 平潭县| 德江县| 诸城市| 通河县| 陇西县| 靖宇县| 安陆市| 扶风县| 凤翔县| 荣昌县| 隆回县| 读书| 六盘水市| 德令哈市| 定日县| 昭平县| 长葛市| 淮阳县| 江城| 泰来县| 海兴县| 宜君县| 紫阳县| 瑞昌市| 夹江县| 无锡市| 泰顺县| 威海市| 浠水县| 田阳县| 雷州市| 泾阳县| 灌阳县| 禄丰县| 黄骅市| 七台河市| 遵义市| 宾川县| 察雅县|