问答题1009/1593数据类型检测的方式有哪些?

难度:
2021-08-22 创建

参考答案:

(1)typeof

1console.log(typeof 2); // number 2console.log(typeof true); // boolean 3console.log(typeof 'str'); // string 4console.log(typeof []); // object 5console.log(typeof function(){}); // function 6console.log(typeof {}); // object 7console.log(typeof undefined); // undefined 8console.log(typeof null); // object

其中数组、对象、null都会被判断为object,其他判断都正确。

(2)instanceof

instanceof可以正确判断对象的类型,其内部运行机制是判断在其原型链中能否找到该类型的原型。

1console.log(2 instanceof Number); // false 2console.log(true instanceof Boolean); // false 3console.log('str' instanceof String); // false 4 5console.log([] instanceof Array); // true 6console.log(function(){} instanceof Function); // true 7console.log({} instanceof Object); // true

可以看到,instanceof只能正确判断引用数据类型,而不能判断基本数据类型。instanceof 运算符可以用来测试一个对象在其原型链中是否存在一个构造函数的 prototype 属性。

(3)constructor

1console.log((2).constructor === Number); // true 2console.log((true).constructor === Boolean); // true 3console.log(('str').constructor === String); // true 4console.log(([]).constructor === Array); // true 5console.log((function() {}).constructor === Function); // true 6console.log(({}).constructor === Object); // true

constructor有两个作用,一是判断数据的类型,二是对象实例通过 constrcutor 对象访问它的构造函数。需要注意,如果创建一个对象来改变它的原型,constructor就不能用来判断数据类型了:

1function Fn(){}; 2 3Fn.prototype = new Array(); 4 5var f = new Fn(); 6 7console.log(f.constructor===Fn); // false 8console.log(f.constructor===Array); // true

(4)Object.prototype.toString.call()

Object.prototype.toString.call() 使用 Object 对象的原型方法 toString 来判断数据类型:

1var a = Object.prototype.toString; 2 3console.log(a.call(2)); 4console.log(a.call(true)); 5console.log(a.call('str')); 6console.log(a.call([])); 7console.log(a.call(function(){})); 8console.log(a.call({})); 9console.log(a.call(undefined)); 10console.log(a.call(null));

同样是检测对象obj调用toString方法,obj.toString()的结果和Object.prototype.toString.call(obj)的结果不一样,这是为什么?

这是因为toString是Object的原型方法,而Array、function等类型作为Object的实例,都重写了toString方法。不同的对象类型调用toString方法时,根据原型链的知识,调用的是对应的重写之后的toString方法(function类型返回内容为函数体的字符串,Array类型返回元素组成的字符串…),而不会去调用Object上原型toString方法(返回对象的具体类型),所以采用obj.toString()不能得到其对象类型,只能将obj转换为字符串类型;因此,在想要得到对象的具体类型时,应该调用Object原型上的toString方法。

最近更新时间:2024-08-10

赞赏支持

预览

题库维护不易,您的支持就是我们最大的动力!