龙空技术网

JavaScript 判断是否为数组

Matrix 968

前言:

当前你们对“js判断是否是object”可能比较看重,我们都想要了解一些“js判断是否是object”的相关文章。那么小编同时在网上收集了一些有关“js判断是否是object””的相关知识,希望各位老铁们能喜欢,小伙伴们一起来了解一下吧!

JavaScript 判断数组的几种方法及其利弊。

1. typeof

对于 Function、String、Number、Undefined 等几种类型的对象来说,他完全可以胜任。但是为 Array 时:

var arr = [1, 2, 3]console.log(typeof arr) // "object"// 同样的console.log(typeof null) // "object"console.log(typeof {}) // "object"

所以不能使用 typeof 来判断。

2. instanceof

instanceof 运算符用于检测构造函数的 prototype 属性是否出现在某个实例对象的原型链上。

var arr = [1, 2 ,3]console.log(arr instanceof Array) // true
3. 原型链(constructor)

一般情况下,除了 undefined 和 null,其它都能使用 constructor 判断类型。

var arr = [1, 2, 3]console.log(arr.__proto__.constructor === Array) // trueconsole.log(arr.constructor === Array) // true// 注意:arr.__proto__ === Array.prototype 为 true。

但是某些情况下,判断是不准确的,比如:

// 构造函数function Fn() {}// 修改原型对象Fn.prototype = new Array()// 实例化对象var fn = new Fn()console.log(fn.constructor === Fn) // falseconsole.log(fn.constructor === Array) // true// 此时的 fn 应该是一个普通对象,而非数组,所以此时使用 constructor 判断是不合适的。
使用 instanceof 和 constructor 的局限性:

使用和声明都必须是在当前页面,比如父页面引用了子页面,在子页面中声明了一个 Array,将其赋值给父页面的一个变量,那么此时做原型链的判断:Array === object.constructor 得到的是 false,原因如下:

Array 属于引用型数据,在传递过程中,仅仅是引用地址的传递。 每个页面的 Array 原生对象所引用的地址是不一样的,在子页面声明的Array 所对应的构造函数是子页面的 Array 对象;父页面来进行判断,使用的 Array 并不等于子页面的 Array。

看代码:

var iframe = document.createElement('iframe')document.body.appendChild(iframe)var xArray = window.frames[window.frames.length - 1].Arrayvar xarr = new xArray()var arr = new Array()// 不同页面,结果并非我们所预期的 true,而是 false 哦!console.log(xarr instanceof Array) // falseconsole.log(xarr.constructor === Array) // false// 同页面才是 true 哦!console.log(arr instanceof Array) // trueconsole.log(arr.constructor === Array) // true
4. Object.prototype.toString

该方法通用。

function isArray(arr) {  return Object.prototype.toString.call(arr) === '[object Array]'}
5. Array.isArray

isArray() 方法是 ES5 标准提供的一个判断数组方法。

function isArray(arr) {  return Array.isArray(arr)}

综上所述,提供一个完整可靠的方法,如下:

function isArray(arr) {  const toString = Object.prototype.toString  const isArray = Array.isArray || function (arg) { return toString.call(arg) === '[object Array]' }  return isArray(arr)}

标签: #js判断是否是object