返回顶部
首页 > 资讯 > 前端开发 > node.js >es6如何判断变量是不是数组
  • 842
分享到

es6如何判断变量是不是数组

2024-04-02 19:04:59 842人浏览 薄情痞子
摘要

小编给大家分享一下es6如何判断变量是不是数组,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! 在es

小编给大家分享一下es6如何判断变量是不是数组,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

在es6中,可以利用Array的isArray()方法来判断变量是不是数组,该方法用于判断一个对象是否为数组类型,语法“Array.isArray(obj)”;如果对象是数组返回true,否则返回false。

教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。

在ES5中判断变量是否为数组

在ES5中,我们至少有如下5种方式去判断一个值是否数组:

var a = []; 
// 1.基于instanceof 
a instanceof Array; 
// 2.基于constructor 
a.constructor === Array; 
// 3.基于Object.prototype.isPrototypeOf 
Array.prototype.isPrototypeOf(a); 
// 4.基于getPrototypeOf 
Object.getPrototypeOf(a) === Array.prototype; 
// 5.基于Object.prototype.toString 
Object.prototype.toString.apply(a) === '[object Array]';

以上,除了Object.prototype.toString外,其它方法都不能正确判断变量的类型。

要知道,代码的运行环境十分复杂,一个变量可能使用浑身解数去迷惑它的创造者。且看

var a = {
    __proto__: Array.prototype
}; 
// 分别在控制台试运行以下代码 
// 1.基于instanceof 
a instanceof Array; // => true 
// 2.基于constructor 
a.constructor === Array; // => true 
// 3.基于Object.prototype.isPrototypeOf 
Array.prototype.isPrototypeOf(a); // => true 
// 4.基于getPrototypeOf 
Object.getPrototypeOf(a) === Array.prototype; // => true

以上,4种方法将全部返回true,为什么呢?我们只是手动指定了某个对象的__proto__属性为Array.prototype,便导致了该对象继承了Array对象,这种毫不负责任的继承方式,使得基于继承的判断方案瞬间土崩瓦解。

不仅如此,我们还知道,Array是堆数据,变量指向的只是它的引用地址,因此每个页面的Array对象引用的地址都是不一样的。iframe中声明的数组,它的构造函数是iframe中的Array对象。如果在iframe声明了一个数组x,将其赋值给父页面的变量y,那么在父页面使用y instanceof Array ,结果一定是false的。而最后一种返回的是字符串,不会存在引用问题。实际上,多页面或系统之间的交互只有字符串能够畅行无阻。

在ES6中判断变量是否为数组

鉴于数组的常用性,在ES6中新增了Array.isArray方法,使用此方法判断变量是否为数组,则非常简单,如下:

Array.isArray([]); // => true 
Array.isArray({0: 'a', length: 1}); // => false

实际上,通过Object.prototype.toString去判断一个值的类型,也是各大主流库的标准。因此Array.isArray的polyfill通常长这样:

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

以上是“es6如何判断变量是不是数组”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网node.js频道!

--结束END--

本文标题: es6如何判断变量是不是数组

本文链接: https://lsjlt.com/news/92508.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • es6如何判断变量是不是数组
    小编给大家分享一下es6如何判断变量是不是数组,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! 在es...
    99+
    2024-04-02
  • es6如何判断一个变量是否为数组
    这篇文章主要讲解了“es6如何判断一个变量是否为数组”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“es6如何判断一个变量是否为数组”吧!判断方法:1、利用Array对象的isArray()函...
    99+
    2023-07-05
  • es6如何判断是否是数组
    这篇文章主要讲解了“es6如何判断是否是数组”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“es6如何判断是否是数组”吧! 3种判...
    99+
    2024-04-02
  • es6如何判断是不是数字
    这篇文章主要介绍“es6如何判断是不是数字”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“es6如何判断是不是数字”文章能帮助大家解决问题。 ...
    99+
    2024-04-02
  • es6如何判断是否为数组
    本篇内容主要讲解“es6如何判断是否为数组”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“es6如何判断是否为数组”吧! 在es6中,...
    99+
    2024-04-02
  • php 判断变量是否是数组
    在PHP中,有时候需要判断一个变量是否是数组。这个判断对于程序的正确执行非常关键,因此需要特别注意。在PHP中,判断一个变量是否是数组可以使用is_array函数,该函数的使用非常简单,只需要将要判断的变量传入该函数中即可。示例代码如下:$...
    99+
    2023-05-19
  • es6如何判断数组是否为空
    本篇内容主要讲解“es6如何判断数组是否为空”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“es6如何判断数组是否为空”吧! es6判...
    99+
    2024-04-02
  • es6如何判断数组是否重复
    这篇文章主要讲解了“es6如何判断数组是否重复”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“es6如何判断数组是否重复”吧! 判...
    99+
    2024-04-02
  • es6如何判断是否在数组里
    这篇文章主要介绍“es6如何判断是否在数组里”,在日常操作中,相信很多人在es6如何判断是否在数组里问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”es6如何判断是否在数组里”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-07-05
  • php如何判断是不是数组
    本篇内容介绍了“php如何判断是不是数组”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!php判断是不是数组的方法:1、创建一个PHP示例文件...
    99+
    2023-06-22
  • php如何判断一个变量是否为数组
    在php中使用is_array()函数判断一个变量是否为数组,具体方法如下:is_array()函数作用:php中is_array()函数的作用是用于检测变量是否是一个数组。is_array()函数语法:bool is_array...
    99+
    2024-04-02
  • php如何判断是不是空数组
    这篇“php如何判断是不是空数组”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“php如何判断是不是空数组”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过这篇文章有所收获,下面让我们一起...
    99+
    2023-06-06
  • es6如何判断一个变量是否为字符串
    本篇内容介绍了“es6如何判断一个变量是否为字符串”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • es6如何判断元素是否在数组中
    本篇内容介绍了“es6如何判断元素是否在数组中”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • es6如何判断两个数组是否相等
    这篇“es6如何判断两个数组是否相等”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“es6如何判断两个数组是否相等”文章吧。步...
    99+
    2023-07-04
  • php如何判断数组是不是为空
    这篇文章主要介绍“php如何判断数组是不是为空”,在日常操作中,相信很多人在php如何判断数组是不是为空问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”php如何判断数组是不是为空”的疑惑有所帮助!接下来,请跟...
    99+
    2023-07-05
  • ES6如何判断是否为小数
    这篇文章主要介绍“ES6如何判断是否为小数”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“ES6如何判断是否为小数”文章能帮助大家解决问题。 ...
    99+
    2024-04-02
  • es6如何判断数组中是否包含对象
    今天小编给大家分享一下es6如何判断数组中是否包含对象的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了...
    99+
    2024-04-02
  • thinkphp如何判断变量是否为数字
    这篇文章给大家分享的是有关thinkphp如何判断变量是否为数字的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。方法:1、用“protected 变量=array(array('your_variable&...
    99+
    2023-06-29
  • php中如何判断一个变量是否为数组中
    在PHP中,有多种方式可以判断一个变量是否为数组类型,下面就是其中几个使用频率较高的方法。 方法一:使用is_array()函数is_array()函数是PHP中判断一个变量是否为数组类型最常用的函数之一。这个函数接受一个参数,它会判断这个...
    99+
    2023-05-23
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作