1、instanceof运算符
let arr = [1, 2, 3];
console.log(arr instanceof Array); //true
2、constructor
实例的构造函数属性constructor指向构造函数本身,那么通过constructor属性也可以判断是否为一个数组。
即Array.prototype.constructor==Array
实例化的数组有一个constructor属性,指向构造函数本身
注意:arr本身没有constructor,但是使用arr.constructor
的时候会根据原型链查找,所以此时arr.constructor
等于arr.__proto__.constructor
let arr = [1, 2, 3];
console.log(arr.constructor == Array); //true
3、ES6新增的数组方法
let arr = [1, 2, 3];
console.log(Array.isArray(arr)); //true
4、Object.pr ototype.toString.call()
把对象转化成字符串和一个已知的对象进行对比。
(该方可可以检测所有类型)
//检验是否为数组
let a = [1,2,3]
Object.prototype.toString.call(a) === '[object Array]';//true
//检验是否是函数
let b = function () {};
Object.prototype.toString.call(b) === '[object Function]';//true
//检验是否是数字
let c = 1;
Object.prototype.toString.call(c) === '[object Number]';//true
//检验是否为对象
let d = {};
Object.prototype.toString.call(d) === '[object Object]' //true
5、对象原型
实例对象的proto指向该构造函数的原型对象
arr.proto===Array.prototype
arr.__proto__===Array.prototype//true
6、Array原型链上的isPrototypeOf
Array.prototype表示Array的构造函数的原型对象;
isPrototypeOf()方法可以判断一个对象是否存在于另一个对象的原型链上。
console.log(Array.prototype.isPrototypeOf(arr));//true
7、Object.getPrototypeOf()
Object.getPrototypeOf()方法返回指定对象的原型,然后和Array的原型对比。
Object.getPrototypeOf()方法返回指定对象的原型,然后和Array的原型对比。
console.log(Object.getPrototypeOf(arr));//Array.prototype
console.log(Object.getPrototypeOf(arr) == Array.prototype);