JavaScript基础知识介绍——面向对象编程(创建类和实例、原型、继承、多态、多继承、混合类)

1. 创建类和实例:

class Car{
   constructor(){
   }
}
const car1 = new Car();
const car2 = new Car();

2. 原型:

每个函数都有一个叫做prototype的特殊属性(可以通过在控制台中输入f.portotype来讲它更改为任意函数)。一把的函数不需要使用原型,但是对于那些作为对象构造器的函数,它就至关重要了

当使用关键字new来创建一个新的实例时,函数的原型属性就会变得很重要:新创建的对象可以访问其构造器的原型对象。对象实例会将它存储在自己的_proto_属性中

_proto_属性是JavaScript的内部属性

关于原型,有一个重要的机制叫做动态调度(“调度”是方法调用的另一种说法)。当试图访问对象的某个属性或者方法时,如果它不存在于当前对象中,JavaScript会检查它是否存在于对象原型中,因为同一个类的所有实例公用同一个原型,如果原型中存在某个属性或方法 ,则该类的所有实例都可以访问这个属性火法

通常不要在类的原型中设置数据属性,因为所有的实例都会共享这些属性的值

注意:在实例中定义的方法或属性会覆盖远行中的定义。记住JavaScript的检查顺序是先实例后原型

3. 静态方法:

也叫类方法,它不与实例绑定。在静态方法中,this绑定的是类本身,但通常使用类名来代替this是公认的最佳实践

通常用来执行一些与类相关的任务,而非跟具体的实例相关

4. 继承:

如果一个方法没有在对象原型中找到其定义,它会检查原型的原型,这样就建立了一个原型链,JavaScript会沿着原型链走下去,直到某个原型满足了需求,如果找不到这样的原型,程序最终会报错

原型链最大的好处是能够建立类的层次结构

原型链允许将功能置于最合适的继承层次上

5. 多态:

JavaScript具备终极的多态性

JavaScript提供了instanceof运算符,它会指出某个对象是否属于某个给定类。也许不够智能,但是紫瑶没设置prototype和_proto_属性,它就是可靠的

JavaScript中所有对象都是基类Object的实例

6. 多继承、混合类和接口:

一个类只能有一个父类,但它可以有多个接口

JavaScript是一种有趣的混合。技术上,它是一个单继承的语言,因为在原型链并不会去寻找多个父类,但它却是提供了一些方法

多继承产生问题的主要原意在于混入的概念。混入是指功能按需“混合”。因为JavaScript是一门弱类型且语法自由的语言,任何时候都可以将任意功能混合到任何对象

 

你可能感兴趣的:(JavaScript,继承,多态,原型,多继承,混合类)