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

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

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

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

一、前言

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

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

1.通過instanceof判斷

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

let a = [];a instanceof Array; //truelet 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;//通過構(gòu)造函數(shù)獲取一個(gè)實(shí)例var arr = new xArray(1,2,3); arr instanceof Array;//false

導(dǎo)致這種問題是因?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.通過constructor判斷

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

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

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

//為body創(chuàng)建并添加一個(gè)iframe標(biāo)簽var iframe = document.createElement(’iframe’);document.body.appendChild(iframe);//取得iframe對(duì)象的構(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()可以獲取到對(duì)象的不同類型,例如

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

甚至對(duì)于多全局環(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對(duì)象的構(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

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

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

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

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

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

參考資料:

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

Array.isArray()---MDN

instanceof---MDN

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

標(biāo)簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品66| 精品一区二区三区的国产在线观看| 国产乱码精品| 国产欧美一区二区色老头| 精品日韩毛片| 久久久久国产精品一区三寸| 美女网站视频一区| 人人香蕉久久| 午夜欧美在线| 在线观看亚洲精品福利片| 日韩一区精品字幕| 日韩欧美在线精品| 91av一区| 久久三级视频| 国产精品中文字幕制服诱惑| 国产亚洲毛片在线| 国产精品115| 9999国产精品| 免费视频一区二区| 久久免费精品| 国产传媒av在线| 国产精品一区二区免费福利视频| 日本少妇精品亚洲第一区| 国产乱人伦精品一区| 成人午夜亚洲| 亚洲成人三区| 欧美综合国产| 日韩一区网站| 久久精品人人| 极品日韩av| 亚州精品视频| 日韩福利视频一区| 精品一区二区三区免费看| 日本久久成人网| 三级一区在线视频先锋| 国产日韩在线观看视频| 国产精品伦一区二区| 色网在线免费观看| 久久久久.com| 日韩在线观看中文字幕| 久久99国产精品视频| 久久亚洲在线| 日韩一区二区三区在线看| 久久久久久婷| 九一成人免费视频| 日韩精彩视频在线观看| 国产精品扒开腿做爽爽爽软件| 精品免费av在线| 久久精品影视| 亚洲四虎影院| 日韩中文字幕区一区有砖一区| 亚洲精品国模| 国产精品麻豆成人av电影艾秋| 欧美日韩尤物久久| 精品国产麻豆| 亚洲h色精品| 亚洲涩涩在线| 欧美高清不卡| 国产精品一区二区av交换| 欧美一区免费| 亚洲性图久久| 亚洲色图网站| 色爱综合网欧美| 婷婷视频一区二区三区| 捆绑调教日本一区二区三区| 中文字幕av一区二区三区四区| 国产91在线精品| 日韩一区二区三区精品视频第3页| 精品深夜福利视频| 一区二区三区网站| 日韩在线综合| 国产精品亚洲四区在线观看 | 97精品中文字幕| 亚洲精品福利| 久久久久一区| 麻豆一区二区三| 免费观看在线综合| 久久裸体视频| 精品伊人久久久| 奇米亚洲欧美| 午夜在线播放视频欧美| 98精品久久久久久久| 日韩av二区在线播放| 伊人久久成人| 日韩精品免费一区二区三区| 国产精品黄网站| 国产综合欧美| 国产亚洲一区二区三区啪| 欧美性感美女一区二区| 精品深夜福利视频| 亚洲精品一区二区在线看| 免费的成人av| 国产免费成人| а√在线中文在线新版| 奶水喷射视频一区| 国产综合婷婷| 亚州精品视频| 巨乳诱惑日韩免费av| 日韩电影二区| 成人在线免费观看网站| 国产精品欧美一区二区三区不卡| 亚洲国产一区二区在线观看| 久久久久久自在自线| 欧美aa在线视频| 亚洲不卡视频| 男女男精品网站| 亚洲激情精品| 伊人久久亚洲美女图片| 亚洲天堂黄色| 久久九九精品| 亚洲日本网址| 欧洲亚洲一区二区三区| 日韩毛片视频| 91精品福利| 在线日韩一区| 国内精品美女在线观看| 日本午夜免费一区二区 | 精品国产不卡一区二区| 麻豆国产欧美一区二区三区| 日韩一区精品| 日韩欧美精品一区二区综合视频| 美女尤物久久精品| 国产亚洲一区在线| 爽好多水快深点欧美视频| 91亚洲国产成人久久精品| 日本少妇精品亚洲第一区| 日韩欧美中文字幕电影| 亚洲深夜av| 婷婷亚洲综合| 亚洲欧美日韩高清在线| 中文字幕系列一区| 四虎影视精品| 亚洲第一精品影视| 免费在线欧美黄色| 激情久久久久久久| 日韩精品一二三区| 国产精品乱战久久久| 中文字幕色婷婷在线视频 | 国产精品主播在线观看| 国产伦乱精品| 久久97视频| 蜜臀精品一区二区三区在线观看| 日韩精品中文字幕一区二区| 精品精品久久| 秋霞国产精品| 亚洲日韩中文字幕一区| 国模大尺度视频一区二区| 国产激情精品一区二区三区| 韩日一区二区三区| 99精品视频在线| 国产精品天天看天天狠| 精品一二三区| 福利片在线一区二区| 麻豆9191精品国产| 亚洲精品99| 国产欧美另类| 国产一区2区| 欧美日韩一二三四| 国产农村妇女精品一区二区| 亚洲国内欧美| 中文一区一区三区免费在线观 | 日本视频一区二区| 国产91精品对白在线播放| 国产在线不卡| 成人日韩av| 麻豆成人91精品二区三区| 日韩一二三区在线观看| 日韩精品午夜视频| 久久久精品久久久久久96| 国产精品久久国产愉拍| 国产一区二区三区自拍| 亚洲视频播放| 欧美中文高清| 神马午夜在线视频| 亚洲一区日韩在线| 国产精品自拍区| 99久久久久国产精品| 日本中文字幕视频一区| 国产精品久久观看| 午夜在线观看免费一区| 国产精成人品2018| 在线日韩中文| 国产欧美在线| 欧美精品激情| 日韩三级久久| 91tv亚洲精品香蕉国产一区| 亚洲精品成a人ⅴ香蕉片| 国产中文字幕一区二区三区| 亚洲深夜福利| 精品久久精品| 亚洲婷婷丁香| 欧美xxxx中国| 日本亚洲视频| 成人精品中文字幕| 青青国产精品| 亚洲精品一二三区区别| 久久精品国产网站| 综合激情网...| 久久美女精品| 国产免费av国片精品草莓男男|