ES5和ES6中,都怎么判断变量是否为数组?
栏目: JavaScript · 发布时间: 5年前
内容简介:JS的弱类型机制导致判断变量类型是初级前端开发者面试时的必考题,一般我都会将其作为考察候选人第一题,然后基于此展开。在ES5中,我们至少有如下5种方式去判断一个值是否数组:以上,除了
JS的弱类型机制导致判断变量类型是初级前端开发者面试时的必考题,一般我都会将其作为考察候选人第一题,然后基于此展开。
在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
的。�而最后一种返回的是字符串,不会存在引用问题。实际上,多页面或系统之间的交互只有字符串能够畅行无阻。
鉴于上述的两点原因,故笔者推荐使用最后一种方法去撩面试官(别提是我说的),如果你还不信,这里恰好有篇文章跟我持有相同的观点: Determining with absolute accuracy whether or not a JavaScript object is an array 。
在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]'; }; }复制代码
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 1.11 JavaScript2:变量、数组、字符串
- SeasLog 1.9.0 发布, 支持修改预设变量及批量记录数组
- SeasLog 1.9.0 发布, 支持修改预设变量及批量记录数组
- 全局变量,静态全局变量,局部变量,静态局部变量
- python变量与变量作用域
- Python基础-类变量和实例变量
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
构建高可用Linux服务器
余洪春 / 机械工业出版社华章公司 / 2011-11-1 / 79.00元
资深Linux/Unix系统管理专家兼架构师多年一线工作经验结晶,51CTO和ChinaUnix等知名社区联袂推荐。结合实际生产环境,从Linux虚拟化、集群、服务器故障诊断与排除、系统安全性等多角度阐述构建高可用Linux服务器的最佳实践。本书实践性非常强,包含大量企业级的应用案例及相应的解决方案,读者可以直接用这些方案解决在实际工作中遇到的问题。 全书一共10章。第1章以作者的项目实践为......一起来看看 《构建高可用Linux服务器》 这本书的介绍吧!