4

我有一个 Square 的实例,它继承自 Rectangle

instance instanceof Rectangle --> true
instance instanceof Square    --> true
instance.area() ; // --> area is defined by Rectangle

现在,在我的代码中,我不知道“区域”函数是在哪里定义的,我想要定义它的原型对象。当然可以遍历原型链(未测试)

var proto = instance ;
while( !(proto = Object.getPrototypeOf(proto)).hasOwnProperty('area') ) {}
// do something with 'proto'

但是,我想知道是否有更好/更快的方法来获取函数所属的原型对象?

4

2 回答 2

5

不,没有。你必须遍历原型链:

function owner(obj, prop) {
    var hasOwnProperty = Object.prototype.hasOwnProperty;
    while (obj && !hasOwnProperty.call(obj, prop))
        obj = Object.getPrototypeOf(obj);
    return obj;
}

现在您只需执行以下操作:

var obj = owner(instance, "area");
console.log(obj === Rectangle);    // true

如果instance或其原型不具有该属性area,则owner返回null

于 2013-08-15T10:05:18.770 回答
1

回复您的评论:您实际上似乎想要的是在继承类的覆盖函数中调用基类的函数。

在您的情况下,我不会打扰原型链,您可以构建base到您的继承模型中:

function Rectangle() {}
Rectangle.prototype.area = function () {
    console.log("rectangle");
};

//setting up inheritance
function Square() {}
Square.prototype = Object.create(Rectangle.prototype);
Square.prototype.base = Rectangle.prototype;

Square.prototype.area = function () {
    this.base.area();
    console.log("square");
};

var square = new Square();
square.area();

小提琴

于 2013-08-15T11:42:25.633 回答