成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術(shù)文章
文章詳情頁

JS判斷數(shù)組四種實(shí)現(xiàn)方法詳解

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

一、前言

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

二、判斷對象是否是數(shù)組的幾種方式

1.通過instanceof判斷

instanceof運(yùn)算符用于檢驗(yàn)構(gòu)造函數(shù)的prototype屬性是否出現(xiàn)在對象的原型鏈中的任何位置,返回一個(gè)布爾值。

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

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

存在問題:

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

其次,當(dāng)我們的腳本擁有多個(gè)全局環(huán)境,例如html中擁有多個(gè)iframe對象,instanceof的驗(yàn)證結(jié)果可能不會符合預(yù)期,例如:

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

導(dǎo)致這種問題是因?yàn)閕frame會產(chǎn)生新的全局環(huán)境,它也會擁有自己的Array.prototype屬性,讓不同環(huán)境下的屬性相同很明顯是不安全的做法,所以Array.prototype !== window.frames[0].Array.prototype,想要arr instanceof Array為true,你得保證arr是由原始Array構(gòu)造函數(shù)創(chuàng)建時(shí)才可行。

2.通過constructor判斷

我們知道,實(shí)例的構(gòu)造函數(shù)屬性constructor指向構(gòu)造函數(shù),那么通過constructor屬性也可以判斷是否為一個(gè)數(shù)組。

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

同樣,這種判斷也會存在多個(gè)全局環(huán)境的問題,導(dǎo)致的問題與instanceof相同。

//為body創(chuàng)建并添加一個(gè)iframe標(biāo)簽var iframe = document.createElement(’iframe’);document.body.appendChild(iframe);//取得iframe對象的構(gòu)造數(shù)組方法xArray = window.frames[window.frames.length-1].Array;//通過構(gòu)造函數(shù)獲取一個(gè)實(shí)例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

它強(qiáng)大的地方在于不僅僅可以檢驗(yàn)是否為數(shù)組,比如是否是一個(gè)函數(shù),是否是數(shù)字等等

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

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

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

4.通過Array.isArray()判斷

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

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

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

三、判斷數(shù)組方法的最終推薦

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

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

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

參考資料:

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

Array.isArray()---MDN

instanceof---MDN

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: JavaScript
相關(guān)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
久久久久国色av免费看影院| 亚洲视频观看| 韩国精品一区二区三区| 久久夜色精品国产欧美乱极品| 日韩精品一区第一页| 日韩亚洲视频在线| 国产精品毛片无遮挡高清| 99免费精品视频| www成人在线观看| 99re这里只有精品首页| 精品国产乱子伦一区| 风间由美一区二区三区在线观看 | 成人激情动漫在线观看| 欧美一区二区在线播放| 国产精品正在播放| 日韩一级二级三级| 不卡av在线免费观看| 日韩精品最新网址| 成人精品视频一区| 久久免费电影网| 欧美日韩精品免费观看视一区二区| 中文一区一区三区高中清不卡| 色综合天天综合色综合av | 九色|91porny| 欧美人妖巨大在线| 国产高清精品久久久久| 欧美成人在线直播| 波多野结衣一区二区三区| 国产午夜亚洲精品不卡| 91首页免费视频| 欧美激情一区二区| 亚洲区国产区| 性久久久久久久久| 欧美三级日韩三级| 高清在线成人网| 国产午夜一区二区三区| 99pao成人国产永久免费视频| 午夜欧美电影在线观看| 欧美日本一区二区三区四区| 成人午夜视频在线观看| 久久久夜色精品亚洲| 在线观看欧美一区| 午夜在线电影亚洲一区| 欧洲国产伦久久久久久久| 国产一二精品视频| 久久日一线二线三线suv| 国产精品大片免费观看| 亚洲影院在线观看| 在线观看一区二区视频| 国产iv一区二区三区| 国产精品污www在线观看| 一区二区三区欧美成人| 久久精品国产精品青草| 精品免费国产二区三区 | 欧美性猛片xxxx免费看久爱| 国产精选一区二区三区| 亚洲国产电影在线观看| 久久av在线| 高清在线观看日韩| 中文字幕av一区二区三区免费看| 国产日韩1区| 久久成人麻豆午夜电影| 久久久久久久久久久久久久久99| 国产欧美一区二区在线| 国产日韩三区| 另类小说综合欧美亚洲| 久久精品一区二区三区不卡| 国产精品一区亚洲| 国产精品自拍三区| 中文字幕一区二区三区四区| 色婷婷狠狠综合| 不卡av电影在线播放| 综合自拍亚洲综合图不卡区| 日本高清成人免费播放| 成人性生交大片免费看在线播放| 国产精品理论在线观看| 在线观看一区日韩| 91同城在线观看| 亚洲高清不卡在线| 欧美成人免费网站| 日韩视频在线播放| 国产精品一区二区在线观看网站| 国产精品午夜免费| 欧美三区在线视频| 一区免费在线| 精品一区精品二区高清| 国产精品三级在线观看| 欧美中文字幕亚洲一区二区va在线| 欧美在线精品一区| 日本成人中文字幕在线视频| 久久久久国产一区二区三区四区 | 精品系列免费在线观看| 国产精品久久久久一区二区三区 | 91性感美女视频| 亚洲五码中文字幕| 精品国产伦一区二区三区免费| 香蕉久久夜色精品国产| 91社区在线播放| 免费视频最近日韩| 最新热久久免费视频| 欧美一区二区在线免费播放| 国产欧美日韩一级| 91免费视频大全| 蜜桃精品视频在线| 亚洲日本va午夜在线电影| 欧美一区二区三区视频在线观看| 亚洲欧美精品在线观看| 欧美aⅴ99久久黑人专区| 久久99在线观看| 亚洲日韩欧美一区二区在线| 日韩丝袜情趣美女图片| 久久综合九色99| 伊人成年综合电影网| 国产成都精品91一区二区三| 亚洲国产精品一区二区久久 | 日日夜夜精品视频免费| 国产调教视频一区| 制服丝袜一区二区三区| 久久亚洲精品欧美| 亚洲韩日在线| 91性感美女视频| 狠狠色丁香久久婷婷综| 亚洲bdsm女犯bdsm网站| 国产精品日产欧美久久久久| 欧美在线免费观看亚洲| 亚洲最新在线观看| 日韩一区二区在线播放| 免费在线观看视频一区| 亚洲天堂av一区| 伊人久久婷婷| 夜夜精品视频一区二区 | 成人精品视频.| av成人毛片| 欧美精品久久天天躁| 国产精品全国免费观看高清| 懂色av中文一区二区三区| 日韩亚洲欧美精品| 欧美在线不卡一区| 日韩欧美一区二区三区在线| 中文成人av在线| 亚洲国产欧美在线| 6080日韩午夜伦伦午夜伦| 同产精品九九九| 欧美综合一区二区三区| av一二三不卡影片| 国产伦精品一区二区三区免费| 视频一区视频二区中文字幕| 亚洲男人天堂av| 国产精品视频一二三| 久久久另类综合| 精品日韩一区二区三区 | 国产成人一区在线| 国产日韩欧美精品电影三级在线| 精品久久99ma| 欧美大片顶级少妇| 日韩一区二区电影在线| 欧美日韩一区二区在线观看视频| 久色成人在线| 免费久久久一本精品久久区| 奇米影视7777精品一区二区| 亚洲 欧美综合在线网络| 亚洲午夜私人影院| 亚洲精品国产视频| 成人欧美一区二区三区黑人麻豆 | 精品sm在线观看| 欧美www视频| 日韩你懂的在线观看| 7777精品伊人久久久大香线蕉完整版| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 欧美影院午夜播放| 欧美美女一区二区| 日韩精品专区在线影院重磅| 正在播放亚洲一区| 日韩欧美色电影| 久久综合九色综合欧美98| 久久久久久久电影| 国产精品欧美久久久久一区二区| 中文字幕在线不卡一区| 亚洲九九爱视频| 亚洲福利电影网| 奇米影视在线99精品| 国内不卡的二区三区中文字幕| 国产伦理精品不卡| 国产91精品免费| 99久久综合狠狠综合久久| 91在线看国产| 国内精品久久久久久久影视麻豆| 欧美日韩喷水| 亚洲区一区二区三区| 国产嫩草一区二区三区在线观看| 亚洲三级观看| 西西裸体人体做爰大胆久久久| 色综合久久久久久久| 在线欧美日韩精品| 91精品国产aⅴ一区二区| 337p粉嫩大胆色噜噜噜噜亚洲| 国产精品视频免费看| 一级特黄大欧美久久久| 日韩成人午夜精品| 国产精品77777|