基于JS判斷對(duì)象是否是數(shù)組
這篇文章主要介紹了基于JS判斷對(duì)象是否是數(shù)組,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
1、通過(guò)instanceof判斷
instanceof運(yùn)算符用于檢驗(yàn)構(gòu)造函數(shù)的prototype屬性是否出現(xiàn)在對(duì)象的原型鏈中的任何位置,返回一個(gè)布爾值。
let a = []; a instanceof Array; //true let b = {}; b instanceof Array; //false
在上方代碼中,instanceof運(yùn)算符檢測(cè)Array.prototype屬性是否存在于變量a的原型鏈上,顯然a是一個(gè)數(shù)組,擁有Array.prototype屬性,所以為true。
需要注意的是,prototype屬性是可以修改的,所以并不是最初判斷為true就一定永遠(yuǎn)為真。
其次,當(dāng)我們的腳本擁有多個(gè)全局環(huán)境,例如html中擁有多個(gè)iframe對(duì)象,instanceof的驗(yàn)證結(jié)果可能不會(huì)符合預(yù)期,例如:
//為body創(chuàng)建并添加一個(gè)iframe對(duì)象 var iframe = document.createElement('iframe'); document.body.appendChild(iframe); //取得iframe對(duì)象的構(gòu)造數(shù)組方法 xArray = window.frames[0].Array; //通過(guò)構(gòu)造函數(shù)獲取一個(gè)實(shí)例 var arr = new xArray(1,2,3); arr instanceof Array;//false
導(dǎo)致這種問(wèn)題是因?yàn)閕frame會(huì)產(chǎn)生新的全局環(huán)境,它也會(huì)擁有自己的Array.prototype屬性,讓不同環(huán)境下的屬性相同很明顯是不安全的做法,所以Array.prototype !== window.frames[0].Array.prototype,想要arr instanceof Array為true,你得保證arr是由原始Array構(gòu)造函數(shù)創(chuàng)建時(shí)才可行。
2、通過(guò)constructor判斷
我們知道,實(shí)例的構(gòu)造函數(shù)屬性constructor指向構(gòu)造函數(shù),那么通過(guò)constructor屬性也可以判斷是否為一個(gè)數(shù)組。
let a = [1,3,4]; a.constructor === Array;//true
同樣,這種判斷也會(huì)存在多個(gè)全局環(huán)境的問(wèn)題,導(dǎo)致的問(wèn)題與instanceof相同。
3、通過(guò)Object.prototype.toString.call()判斷
Object.prototype.toString().call()可以獲取到對(duì)象的不同類型,多個(gè)全局環(huán)境也適用
// 檢驗(yàn)是否是數(shù)組 let a = [1,2,3] Object.prototype.toString.call(a) === '[object Array]';//true //檢驗(yàn)是否是函數(shù) let b = function () {}; Object.prototype.toString.call(b) === '[object Function]';//true //檢驗(yàn)是否是數(shù)字 let c = 1; Object.prototype.toString.call(c) === '[object Number]';//true
4、通過(guò)Array.isArray()判斷
簡(jiǎn)單好用,而且對(duì)于多全局環(huán)境,Array.isArray() 同樣能準(zhǔn)確判斷,但有個(gè)問(wèn)題,Array.isArray() 是在ES5中提出,也就是說(shuō)在ES5之前可能會(huì)存在不支持此方法的情況。
let a = [1,2,3] Array.isArray(a);//true
最終推薦方法
if (!Array.isArray) { Array.isArray = function(arg) { return Object.prototype.toString.call(arg) === '[object Array]'; }; }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
上一篇:沒(méi)有了
欄 目:JavaScript
下一篇:沒(méi)有了
本文標(biāo)題:基于JS判斷對(duì)象是否是數(shù)組
本文地址:http://mengdiqiu.com.cn/a1/JavaScript/9219.html
您可能感興趣的文章
- 01-10JS精確判斷數(shù)據(jù)類型代碼實(shí)例
- 01-10js判斷一個(gè)對(duì)象是數(shù)組(函數(shù))的方法實(shí)例
- 01-10vue中根據(jù)時(shí)間戳判斷對(duì)應(yīng)的時(shí)間(今天 昨天 前天)
- 01-10判斷JavaScript中的兩個(gè)變量是否相等的操作符
- 01-10JQuery中的常用事件、對(duì)象屬性與使用方法分析
- 01-10如何基于JS截獲動(dòng)態(tài)代碼
- 01-10node.js Promise對(duì)象的使用方法實(shí)例分析
- 01-10如何基于JavaScript判斷圖片是否加載完成
- 01-10JavaScript 變量,數(shù)據(jù)類型基礎(chǔ)實(shí)例詳解【變量、字符串、數(shù)組、對(duì)
- 01-10js判斷非127開(kāi)頭的IP地址的實(shí)例代碼


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02javascript點(diǎn)線,點(diǎn)線的代碼
- 04-02javascript潛力,javascript強(qiáng)大嗎
- 04-02javascript替換字符串,js字符串的替換
- 04-02javascript移出,js 移入移出
- 04-02包含javascript舍的詞條
- 04-02javascript并行,深入理解并行編程 豆瓣
- 04-02javascript匿名,js匿名方法
- 04-02javascript警報(bào),JavaScript警告
- 04-02javascript遮蓋,JavaScript遮蓋PC端頁(yè)面
- 04-02javascript前身,javascript的前身
隨機(jī)閱讀
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-10C#中split用法實(shí)例總結(jié)
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 04-02jquery與jsp,用jquery
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10delphi制作wav文件的方法
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?