每个对象中都会有一个 isPrototypeOf()方法,这个方法会告诉我们当前对象是否
是另一个对象的原型。
让我们先来定义一个简单的对象 monkey:
var monkey = {
hair: true,
feeds: 'bananas',
breathes: 'air'
};
然后,我们再创建一个叫做 Human()的构造器函数,并将其原型属性设置为指向
monkey:
function Human(name) {
this.name = name;
}
Human.prototype = monkey;
现在,如果我们新建一个叫做 george 的 Human 对象,并提问“monkey 是 george
的原型吗?”,答案是 true。
> var george = new Human('George');
> monkey.isPrototypeOf(george);
true
需要注意的是,我们在这里是预先知道了 monkey 可能是 george 的原型,才提出了
问题“monkey 是你的原型吗?”,然后获得一个布尔值作为回应。那么,是否能在不知道
某个对象原型是什么的情况下,获得对象的原型呢?答案是:大多数浏览器可以。因为大
多数浏览器都实现了 ES5 的 Object.getPrototypeOf()方法。
> Object.getPrototypeOf(george).feeds;
"banana"
> Object.getPrototypeOf(george) === monkey;
true
而对于另一部分实现了 ES5 部分功能,却没有实现 getPrototypeOf()方法的浏览
器,我们可以使用特殊属性__proto__。