学习继承遇到的难点

    xiaoxiao2022-07-14  153

    学习继承遇到的难点 1.所有引用类型默认都继承了Object,这个继承也是通过原型链实现的。 比如我这里有一个构造函数SuperType,它是如何继承Object的呢?我认为可以用下面的代码说明

    SuperType.prototype = new Object()

    SuperType.prototype 其实相当Object的一个实例,我们可以看看这个关系是否成立?

    console.log(SuperType.prototype instanceof Object);

    结果返回了true,说明的确是这样。

    2.所有函数的默认原型都是Object实例,为什么呢?

    SuperType.prototype = new Object()

    因为函数的原型是一个对象,Object是任何对象的实例。 3.可以通过两种方式确定实例和原型之间的关系 第一种是使用instanceof操作符,只要用这个操作符来测试实例与原型链上出现过的构造函数,就返回true。如何理解这句话?

    function SuperType(){} Super.prototype.getSuperValue = function(){ return this.property = '父类'; } function SubType(){} SubType.prototype = new SuperType(); SubType.prototype.getSubValue = function(){ return this.subproperty = '子类'; } var instance = new SubType();

    实例上出现的构造函数有:SubType、SuperType。其实还有一个Object,我认为是隐藏的,下面这行代码应该自身实现的。

    SuperType.prototype = new Object()

    但我还有一个疑惑点,原型链上出现的构造函数有什么?

    SubType.prototype = new SuperType();

    SubType.prototype的原型中包含一个内部指针指向了SuperType的原型。 比如SuperType应该就是原型链上出现的构造函数。 4.第二种方式是使用isPrototypeOf()方法。只要是原型链出现过的原型,都可以说是该原型链派生的实例的原型,因此isPrototypeOf()也会返回true。

    Object.prototype.isPrototypeOf(instance); SuperType.prototype.isPrototypeOf(instance); SubType.prototype.isPrototypeOf(instance);
    最新回复(0)