加入收藏 | 设为首页 | 会员中心 | 我要投稿 晋中站长网 (https://www.0354zz.com/)- 科技、容器安全、数据加密、云日志、云数据迁移!
当前位置: 首页 > 教程 > 正文

es6如何判定一个变量是否为数组

发布时间:2023-07-15 11:00:29 所属栏目:教程 来源:网络
导读:   这篇文章主要讲解了“es6如何判断一个变量是否为数组”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“es6如何判断
  这篇文章主要讲解了“es6如何判断一个变量是否为数组”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“es6如何判断一个变量是否为数组”吧!
 
  判断方法:1、利用Array对象的isArray()函数来判断变量是不是数组,语法“Array.isArray(obj)”,如果是数组返回true,否则返回false。2、通过“Object.prototype.toString()”来判断,语法“Object.prototype.toString.apply(a) === '[object Array]'”。

  在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中新增了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]';
 
      };
 
  }
 

(编辑:晋中站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章