Home >Web Front-end >JS Tutorial >How to determine whether a variable is an array in es6

How to determine whether a variable is an array in es6

青灯夜游
青灯夜游Original
2022-03-08 16:50:223475browse

In es6, you can use Array's isArray() method to determine whether a variable is an array. This method is used to determine whether an object is an array type. The syntax is "Array.isArray(obj)"; if the object is Array returns true, otherwise returns false.

How to determine whether a variable is an array in es6

The operating environment of this tutorial: Windows 7 system, ECMAScript version 6, Dell G3 computer.

Determine whether a variable is an array in ES5

In ES5, we have at least the following 5 ways to determine whether a value is an array:

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]';

Above, except Object.prototype.toString, no other method can correctly determine the type of the variable.

You must know that the running environment of the code is very complex, and a variable may use all kinds of tricks to confuse its creator. Looking at

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

above, all four methods will return true. Why? We just manually specified the __proto__ attribute of an object as Array.prototype, which caused the object to inherit the Array object. This irresponsible inheritance method caused the judgment scheme based on inheritance to instantly collapse.

Not only that, we also know that Array is heap data, and the variable only points to its reference address, so the address referenced by the Array object of each page is different. For an array declared in an iframe, its constructor is the Array object in the iframe. If an array x is declared in the iframe and assigned to the variable y of the parent page, then y instanceof Array is used on the parent page, and the result must be false. The last one returns a string, so there is no reference problem. In fact, interactions between multiple pages or systems are only possible with strings.

Determine whether a variable is an array in ES6

In view of the common use of arrays, the Array.isArray method is added in ES6, use This method is very simple to determine whether a variable is an array, as follows:

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

In fact, it is also the standard of major mainstream libraries to determine the type of a value through Object.prototype.toString . Therefore, the polyfill of Array.isArray usually looks like this:

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

[Related recommendations: javascript video tutorial, web front-end]

The above is the detailed content of How to determine whether a variable is an array in es6. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn