溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

在JS中檢查變量是否為數(shù)組的方式有哪些

發(fā)布時(shí)間:2021-10-28 18:09:53 來源:億速云 閱讀:112 作者:iii 欄目:web開發(fā)

這篇文章主要介紹“在JS中檢查變量是否為數(shù)組的方式有哪些”,在日常操作中,相信很多人在在JS中檢查變量是否為數(shù)組的方式有哪些問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”在JS中檢查變量是否為數(shù)組的方式有哪些”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!

下面的代碼片段用于檢查變量或值是否為數(shù)組。在主流的瀏覽器可以使用Array.isArray方法。對(duì)于較舊的瀏覽器,可以使用polyfill

const variable = ['?', '?', '?'];  // 主流瀏覽器 Array.isArray(variable);  // 老式瀏覽器 Object.prototype.toString.call(variable) === '[object Array]';

檢查數(shù)組的現(xiàn)代方法

檢查數(shù)組的最佳方法是使用內(nèi)置的Array.isArray()

Array.isArray([]); // true Array.isArray(['?']); // true Array.isArray(new Array('?')); // true

瀏覽器支持

瀏覽器對(duì) Array.isArray()的支持非常好

在JS中檢查變量是否為數(shù)組的方式有哪些

適用于舊版瀏覽器的 Polyfill

如果需要讓較早的瀏覽器支持,則可以使用此MDN polyfill。

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

其它方式:使用 Lodash 或 Underscore

如果你使用的是外部庫,它們也有一些內(nèi)置方法??

Lodash

檢查值是否為數(shù)組對(duì)象。

const array = ['?', '?', '?']; const notArray = 'not array';  _.isArray(array); // true _.isArray(notArray); // false

Underscore

如果對(duì)象是數(shù)組,返回 true。

const array = ['?', '?', '?']; const notArray = 'not array';  _.isArray(array); // true _.isArray(notArray); // false

為什么我們不能使用typeof?

通常,我們要檢查值的類型,我們只需使用 typeof

typeof 'string'; // 'string' typeof 100; // 'number' typeof true; // 'boolean' typeof false; // 'boolean' typeof function() {}; // 'function' typeof {}; // 'object'  typeof []; // 'object' <-- ?

問題是數(shù)組實(shí)際上處于 Object 數(shù)據(jù)類型的保護(hù)傘之下。所以typeof  返回值是沒問題。不幸的是,這對(duì)我們并沒有什么幫助,因?yàn)槲覀冎幌霗z查值是不是數(shù)組。

typeof

Type例子返回值
Stringtypeof "hello""string"
Booleantypeof true
 typeof false
"boolean"
Numbertypeof 100"number"
Undefinedtypeof undefined"undefined"
Functiontypeof function() {}"function"
Nulltypeof null"object"
非基本類型typeof {}
typeof []
"object"

基本類型

在 JS 中有 6 種基本數(shù)據(jù)類型

  1. 鴻蒙官方戰(zhàn)略合作共建——HarmonyOS技術(shù)社區(qū)

  2. string

  3. number

  4. bigint

  5. boolean

  6. undefined

  7. symbol

非基本類型 (對(duì)象)

對(duì)象是指包含數(shù)據(jù)和使用數(shù)據(jù)的指令的數(shù)據(jù)結(jié)構(gòu)。它們是通過引用存儲(chǔ)的

我比較喜歡稱它為“非基本類型 ”,但它們被稱為Object。

  1. 鴻蒙官方戰(zhàn)略合作共建——HarmonyOS技術(shù)社區(qū)

  2. object

  3. array

  4. function

盡管當(dāng)我們?cè)诤瘮?shù)上使用typeof來檢查函數(shù)的類型,它返回“ function”,但實(shí)際上它是一個(gè)對(duì)象。

》 MDN:盡管每個(gè) Function 構(gòu)造函數(shù)都是從 Object 構(gòu)造函數(shù)派生的,但它是Function的特殊簡(jiǎn)寫形式。

代碼診斷

我收到了很多開發(fā)都提供用來檢查Array的不同解決方案。乍一看,它們似乎是不錯(cuò)的解決方案。有點(diǎn)遺憾的是,有些問題或極端情況使它們不理想。

Array.length 的問題

const array = ['?', '?', '?'];  array.length; // 3

如果數(shù)組有長(zhǎng)度,我們可以假設(shè)它是數(shù)組?

遺憾的是,此解決方案的問題在于還有其他具有長(zhǎng)度即即的數(shù)據(jù)類型,如:字符串。因此,這可能導(dǎo)致誤報(bào)。

const string = 'not array';  string.length; // 9

即使一個(gè)對(duì)象也可以有l(wèi)ength屬性:

const object = { length: 2 }; const array = ['?', '?', '?'];  typeof array === 'object' && Boolean(array.length); // true typeof object === 'object' && Boolean(object.length); // true <-- ?

instanceof 的問題

const array = ['?', '?', '?'];  array instanceof Array; // true

這種方法在 ES5 很常見, 在許多情況下,這種可以很好的工作。但是,這有一個(gè)陷阱!它不適用于多個(gè)上下文(例如 框架  或windows)。因?yàn)槊總€(gè)框架在其自己的執(zhí)行環(huán)境中都有不同的作用域。因此,它具有不同的全局對(duì)象和不同的構(gòu)造函數(shù)。因此,如果嘗試針對(duì)該框架的上下文測(cè)試數(shù)組,則該數(shù)組不會(huì)返回true,而會(huì)錯(cuò)誤地返回false。

window.frames: frames[]  是窗口中所有命名的框架組成的數(shù)組。這個(gè)數(shù)組的每個(gè)元素都是一個(gè)Window對(duì)象,對(duì)應(yīng)于窗口中的一個(gè)框架。

const frameNode = document.createElement('iframe'); // 創(chuàng)建一個(gè)iframe元素節(jié)點(diǎn) document.body.appendChild(frameNode); // 從我們當(dāng)前的窗口訪問框架 const frameBrowser = window.frames[window.frames.length - 1]; // 訪問我們創(chuàng)建的框架的“數(shù)組”對(duì)象 frameArray = frameBrowser.Array;   // 在我們的框架環(huán)境中創(chuàng)建一個(gè)新的數(shù)組 const newFrameArray = new frameArray('?', '?', '?');  newFrameArray instanceof Array; // ? false  Array.isArray(newFrameArray); // ? true

構(gòu)造函數(shù)的問題

const array = ['?', '?', '?'];  array.constructor === Array; // true

這是另一個(gè)很好的解決方案。不幸的是,這和instanceof有同樣的問題。它也不能在多個(gè)上下文中工作。

// ...  newFrameArray.constructor === Array; // ? false  Array.isArray(newFrameArray); // ? true

到此,關(guān)于“在JS中檢查變量是否為數(shù)組的方式有哪些”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

js
AI