一、子类继承父类的所有属性和方法
当一个类被另一个类继承时,子类会继承父类所有的属性和方法。这意味着,子类可以访问和使用父类的所有属性和方法。
下面是一个基本的例子:
class Animal { constructor(name) { this.name = name; } speak() { console.log(this.name + ' makes a noise.'); } } class Dog extends Animal { speak() { console.log(this.name + ' barks.'); } } let dog = new Dog('Rex'); dog.speak(); // output: Rex barks.
在这个例子中,Dog类继承了Animal类的constructor和speak方法,因此它可以使用父类的所有属性和方法。
二、子类继承父类的所有属性和方法JS
在JavaScript中,可以使用Object.create()方法创造一个原型对象。一个子类可以通过Object.create()方法创建一个继承了父类原型的新对象。
下面是一个例子:
let Animal = { speak() { console.log(this.name + ' makes a noise.'); } }; let Dog = Object.create(Animal); Dog.speak = function() { console.log(this.name + ' barks.'); } let dog = Object.create(Dog); dog.name = 'Rex'; dog.speak(); // output: Rex barks.
在这个例子中,Animal是一个包含speak方法的对象。Dog通过继承Animal对象使用Object.create()方法创建。然后,它重写了speak方法以实现自己的独特行为。最后,一个新的狗对象被创建并被赋予名字“Rex”,并且它可以使用从Dog继承的speak方法。
三、子类可以继承父类所有属性和方法
子类可以继承所有的父类属性和方法,包括静态属性和方法。
下面是一个例子:
class Animal { static staticMethod() { console.log('This is a static method.'); } speak() { console.log(this.name + ' makes a noise.'); } } class Dog extends Animal {} Dog.staticMethod(); // output: This is a static method. let dog = new Dog(); dog.name = 'Rex'; dog.speak(); // output: Rex makes a noise.
在这个例子中,Dog继承了Animal的静态方法和实例方法。
四、子类继承父类的所有成员
子类不仅继承了父类的所有属性和方法,还会继承构造函数中内部初始化的所有成员变量。
下面是一个例子:
class Animal { constructor(name) { this.name = name; this.sound = 'makes a noise.'; } speak() { console.log(this.name + ' ' + this.sound); } } class Dog extends Animal { constructor(name) { super(name); this.sound = 'barks.'; } } let dog = new Dog('Rex'); dog.speak(); // output: Rex barks.
在这个例子中,Dog类继承了Animal类的构造函数,并且重写了sound属性,因此它可以使用从父类继承的所有属性和方法,包括构造函数中初始化的成员变量。
五、子类继承父类所有属性值
当子类继承父类时,子类将继承父类所有属性和属性值。
下面是一个例子:
class Animal { constructor(name) { this.name = name; } speak() { console.log(this.name + ' makes a noise.'); } } class Dog extends Animal { constructor(name) { super(name); this.sound = 'barks.'; } } let dog = new Dog('Rex'); console.log(dog.name); // output: Rex console.log(dog.hasOwnProperty('name')); // output: true console.log(dog.hasOwnProperty('sound')); // output: true
在这个例子中,Dog继承了Animal类的属性和属性值,并且它可以使用从父类继承的所有属性和方法。
六、子类在继承父类的属性和方法之后
子类在继承了父类的属性和方法之后,可以使用super关键字来调用父类的方法或构造函数。
下面是一个例子:
class Animal { constructor(name) { this.name = name; } speak() { console.log(this.name + ' makes a noise.'); } } class Dog extends Animal { constructor(name) { super(name); this.sound = 'barks.'; } speak() { super.speak(); console.log(this.name + ' ' + this.sound); } } let dog = new Dog('Rex'); dog.speak(); // output: Rex makes a noise. Rex barks.
在这个例子中,Dog类继承了Animal类的speak方法,并且通过使用super.speak()来调用从父类继承的speak方法。
七、子类继承父类的私有属性怎么访问
子类不能直接访问父类的私有属性,但是可以通过getter和setter方法来获取或修改父类的私有属性。
下面是一个例子:
class Animal { constructor(name) { let sound = 'makes a noise.'; this.getName = function() { return name; } this.getSound = function() { return sound; } } speak() { console.log(this.getName() + ' ' + this.getSound()); } } class Dog extends Animal { constructor(name) { super(name); let sound = 'barks.'; this.getSound = function() { return sound; } } } let dog = new Dog('Rex'); dog.speak(); // output: Rex barks.
在这个例子中,Animal类的sound属性是私有属性,不被子类直接访问。但是,通过在构造函数和子类中定义getter方法,还是可以获取和修改父类的私有属性。
八、子类能继承父类的私有属性吗
子类不能继承父类的私有属性。私有属性是只在父类中可见的,子类无法通过任何方式访问它们。