欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

instanceof 和 typeof的区别

程序员文章站 2022-07-08 16:46:55
...

undefined, number, string, boolean属于简单的值类型,不是对象。剩下的几种情况——函数、数组、对象、null、new Number(10)都是对象。他们都是引用类型。

instanceof 和 typeof的区别

简单的值类型用typeof就可以分辨清楚了,但是就是typeof来判断引用类型的类型并不准确。比如数组、正则、日期、对象的typeof返回值都是object,函数返回的就是function,这种返回太粗糙了。

函数和对象的关系: 函数是一种对象,但函数不像数组、正则、日期这些对象。其他的对象(函数除外)都是对象的一个子集,但是函数却可以创造出对象

function People() {
    this.name = 'qintao';
    this.birth = 1996;
}
var people1 = new People(); //people1就是创造出来的对象

对于值类型,你可以通过typeof判断,string/number/boolean都很清楚,但是typeof在判断到引用类型的时候,返回值只有object/function,你不知道它到底是一个object对象,还是数组,还是new Number等等。这个时候就可以使用instanceof。使用instanceof有很多细节问题 。

先看下面这个例子people这个对象是People创造出来的,但是people instanceof Object也是正确的。

Instanceof 的使用规则是: A instanceof B

A沿着proto这条线来找,同时B沿着prototype这条线来找,如果两条线能找到同一个引用,即同一个对象,那么就返回true。如果找到终点还未重合,则返回false。

instanceof 和 typeof的区别

按照上图的原则有

function Foo() {}
var foo = new Foo();
console.log(foo instanceof Foo);    //true
console.log(foo instanceof Object); //true
console.log(Function instanceof Object); //true

instanceof 和 typeof的区别