日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

JS判斷數組四種實現方法詳解

瀏覽:176日期:2024-05-02 11:21:37

一、前言

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

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

1.通過instanceof判斷

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

let a = [];a instanceof Array; //truelet 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]’; };}

那么對于數組判斷的幾種方式也說完了,合理的推薦也給出了,有什么問題或者錯誤的地方歡迎大家支持

參考資料:

Determining with absolute accuracy whether or not a JavaScript object is an array

Array.isArray()---MDN

instanceof---MDN

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
99pao成人国产永久免费视频| 亚洲一区日韩| 日韩精品社区| 青草久久视频| 三上悠亚国产精品一区二区三区 | 美女精品在线观看| 国产毛片一区| 综合激情网站| 91精品麻豆| 日欧美一区二区| 青青青国产精品| 欧美国产极品| 色网在线免费观看| 久久视频精品| 亚洲综合不卡| 人人精品久久| 久久成人av| 蜜桃精品在线| 中文日韩在线| 日韩精品一级| 久久精品免视看国产成人| 中文在线а√在线8| 合欧美一区二区三区| 日欧美一区二区| 久久国产乱子精品免费女| 精品一区二区三区中文字幕 | 欧美日韩一区二区三区视频播放| 伊人久久大香线蕉av不卡| 免费成人av在线播放| 国产欧美在线观看免费| 国产资源在线观看入口av| 午夜精品免费| 夜夜嗨av一区二区三区网站四季av| 亚洲久久一区| 麻豆久久一区| 欧美日韩精品免费观看视欧美高清免费大片| 99久久亚洲精品| 亚洲一区二区网站| 欧美亚洲色图校园春色| 久久影院午夜精品| 国产精品日韩| 国产精品巨作av| 99久久九九| 91精品国产自产观看在线| 91视频一区| 久热re这里精品视频在线6| 国产精品中文| 欧美日一区二区| 国产精品一区免费在线| 日韩精品一区二区三区免费观看| 一级欧美视频| 黄色欧美在线| 亚洲免费中文| 激情不卡一区二区三区视频在线| 亚洲在线一区| 国产一区不卡| 亚洲人成网站在线在线观看| 国产精选在线| 中文字幕日韩亚洲| 日韩大片在线观看| 欧美在线91| 91国语精品自产拍| 精品亚洲二区| 亚洲视频电影在线| 亚洲精品2区| 精品视频自拍| 亚洲免费资源| 日韩欧美字幕| 国产欧美日韩在线观看视频| 欧美日韩精品免费观看视频完整| 美女久久久精品| 亚洲精品黄色| 久久国产中文字幕| 麻豆视频久久| 天堂久久av| 欧美.日韩.国产.一区.二区 | 天堂日韩电影| 国产精品亚洲成在人线| 婷婷丁香综合| 国产91在线精品| 日韩精选在线| 在线亚洲自拍| 午夜精品成人av| 国产高清视频一区二区| 亚洲精品高潮| 午夜精品婷婷| 久久视频国产| 日韩伦理在线一区| 久久精品国产99国产| 久久国际精品| 亚洲永久精品唐人导航网址| 日本成人一区二区| 日韩亚洲在线| 欧美一级精品| 福利在线免费视频| 久久久精品区| 国产精品美女久久久久久不卡| 在线看片一区| 美女黄网久久| 丝袜美腿成人在线| 日韩亚洲国产欧美| 国产精品99免费看| 精品免费av在线| 岛国av在线网站| 色一区二区三区四区| 精品久久中文| 毛片不卡一区二区| 国产精品网站在线看| 国产欧美日韩在线观看视频| 亚洲精品欧美| 免费观看日韩电影| 久久一二三区| 国产亚洲福利| 黄色免费成人| 免费国产自久久久久三四区久久 | 国产精品2区| 国产精品夜夜夜| 日韩不卡在线观看日韩不卡视频| 日韩一二三区在线观看| 色8久久久久| 日韩精品a在线观看91| 青草国产精品| 国产欧美在线观看免费| 日韩av一二三| 久久精品xxxxx| 国产精品xxx| 精品伊人久久久| 国产成人免费精品| 欧美精品高清| 在线一区视频观看| 欧美午夜精彩| 9色精品在线| 老牛国产精品一区的观看方式| 亚洲一区二区毛片| 亚洲精品影视| 国产精品免费不| 成人三级高清视频在线看| 99tv成人| 视频在线观看91| 日韩精品导航| 精品视频高潮| 欧美亚洲国产激情| 综合在线一区| 国产精品久久国产愉拍| 嫩草伊人久久精品少妇av杨幂| 国产一区二区三区黄网站 | 免费日韩成人| 国产福利片在线观看| 亚洲先锋成人| 日韩制服丝袜先锋影音| 啪啪亚洲精品| 国产一区二区三区四区五区| 久久夜夜操妹子| 亚洲中字黄色| 国产美女视频一区二区| 91亚洲国产| 亚州av乱码久久精品蜜桃| 亚洲免费资源| 精品国产不卡一区二区| 亚洲www免费| 亚洲麻豆一区| 日本精品黄色| 久久国产精品毛片| 国产精品videossex久久发布| 欧美aa在线观看| 蜜桃视频一区二区| 久久精品五月| 中文精品视频| 国产精品久久久免费| 亚洲v在线看| 日韩激情网站| 日韩另类视频| 欧美日韩精品一区二区三区在线观看| 国产一区二区三区精品在线观看| 亚洲高清不卡| 欧美一级二级三级视频| 999久久久精品国产| 日本aⅴ精品一区二区三区 | 国产精品毛片久久久| 99视频精品全国免费| 少妇精品久久久一区二区| 国产999精品在线观看| 综合国产精品| 高清av不卡| 一区二区91| 日韩和的一区二在线| 日韩有吗在线观看| 日韩av免费| 国产精品一区二区美女视频免费看| 久久久久久免费视频| 国产欧美一区| 亚洲主播在线| 日韩高清成人| 中文字幕免费一区二区| 欧美一区久久久| 国产日韩亚洲欧美精品| 一区久久精品| 风间由美中文字幕在线看视频国产欧美| 亚洲欧美日韩综合国产aⅴ| 精品久久一区|