首页 > 编程笔记 > JavaScript笔记 > JS面向对象编程

JS isPrototypeOf()方法:检测一个对象是否存在于另一个对象的原型链中

JavaScript isPrototypeOf() 是 Object 的原型方法(也称实例方法),它定义在 Object.prototype 对象之上,所有 Object 的实例对象都会继承 isPrototypeOf() 方法。

isPrototypeOf() 方法用来检测一个对象是否存在于另一个对象的原型链中,如果存在就返回 true,否则就返回 false。

isPrototypeOf() 的语法格式如下:

prototypeObject.isPrototypeOf(object);

参数说明:object 参数是 Object 类型的一个对象,将对其原型链进行检查。

返回值:isPrototypeOf() 函数的返回值为 Boolean 类型。如果 object 的原型链中存在 prototypeObject 对象,那么返回 true;如果 object 不是对象,或者 object 的原型链中不存在 prototypeObject 对象,那么返回 false。

JavaScript 中,Function 对象预定义了 prototype 属性,该属性指向一个原型对象。当定义构造函数时,系统会自动创建一个对象,并传递给 prototype 属性,这个对象被称为原型对象。原型对象可以存储结构类型的原型属性,以便于所有实例对象共享。

示例1

下面代码为自定义类型函数定义两个原型成员。
var f = function () {}  //定义函数
f.prototype = {  //函数的原型对象
    a : 1,
    b : function () {
        return 2;
    }
}
console.log(f.prototype.a);  //读取函数的原型对象的属性a,返回1
console.log(f.prototype.b());  //读取函数的原型对象的属性b,返回2
当使用 new 运算符调用函数时,就会创建一个实例对象,这个实例对象将继承构造函数的原型对象中所有的属性。
var o = new f();  //实例对象
console.log(o.a);  //访问原型对象的属性
console.log(o.b());  //访问原型对象的属性
为了方便判定,Object 对象定义了 isPrototypeOf() 方法,该方法可以检测一个对象的原型对象。

示例2

通过下面示例,可以判断 f.prototype 就是对象 o 的原型对象,因为其返回值为 true。
var b = f.prototype.isPrototypeOf(o);
console.log(b);

示例3

下面示例演示了各种特殊对象的原型对象。

1) 函数的原型对象可以是 Object.prototype,或者是 Function.prototype。
var f = function () {}
console.log(Object.prototype.isPrototypeOf(f));  //返回true
console.log(Function.prototype.isPrototypeOf(f));  //返回true

2) Object 和 Function 对象的原型对象比较特殊。
console.log(Function.prototype.isPrototypeOf(Object));  //返回true
console.log(Object.prototype.isPrototypeOf(Function));  //返回true

3) Object.prototype 和 Function.prototype 的原型对象不是 Object.prototype,Function.prototype 的原型对象可以是 Function.prototype,但是 Object.prototype 的原型对象绝对不是 Function.prototype。
console.log(Object.prototype.isPrototypeOf(Object.prototype));  //返回false
console.log(Object.prototype.isPrototypeOf(Function.prototype));  //返回true
console.log(Function.prototype.isPrototypeOf(Function.prototype));  //返回false
console.log(Function.prototype.isPrototypeOf(Object.prototype));  //返回false

所有教程

优秀文章