Heim > Web-Frontend > Front-End-Fragen und Antworten > So implementieren Sie Polymorphismus in JavaScript

So implementieren Sie Polymorphismus in JavaScript

PHPz
Freigeben: 2023-05-12 16:52:37
Original
809 Leute haben es durchsucht

JavaScript ist eine dynamische, objektorientierte Programmiersprache, die Polymorphismus unterstützt. Polymorphismus bedeutet, dass dieselbe Methode in unterschiedlichen Situationen unterschiedliche Verhaltensweisen zeigen kann, was für die Flexibilität und Skalierbarkeit des Programms von großer Bedeutung ist. In diesem Artikel werden wir untersuchen, wie Polymorphismus in JavaScript implementiert wird.

Polymorphismus in JavaScript wird basierend auf seinen objektorientierten Funktionen erreicht. Die objektorientierte Programmierung in JavaScript wird hauptsächlich durch Objekte und Prototypen implementiert. Wir implementieren Polymorphismus auf die folgenden zwei Arten.

  1. Vererbung verwenden

In JavaScript kann ein Objekt die Eigenschaften und Methoden eines anderen Objekts erben. Vererbung bietet eine Möglichkeit, Polymorphismus zu erreichen. Wir können Methoden mit demselben Namen in Unterklassen und übergeordneten Klassen definieren und in verschiedenen Situationen unterschiedliche Implementierungen für diese Methode bereitstellen. Die Implementierung der übergeordneten Klasse kann über das Schlüsselwort super aufgerufen werden.

Das Folgende ist ein einfaches Beispiel:

class Animal {
  speak() {
    console.log('Animal is speaking.')
  }
}

class Dog extends Animal {
  speak() {
    console.log('Woof!')
  }
}

class Cat extends Animal {
  speak() {
    console.log('Meow!')
  }
}

let animal = new Animal()
let dog = new Dog()
let cat = new Cat()

animal.speak() // 输出 "Animal is speaking."
dog.speak() // 输出 "Woof!"
cat.speak() // 输出 "Meow!"
Nach dem Login kopieren

Im obigen Beispiel haben wir eine übergeordnete Klasse „Tier“ und zwei Unterklassen „Hund“ und „Katze“ erstellt. Sie alle überschreiben die speak()-Methode und implementieren unterschiedliche Verhaltensweisen in verschiedenen Situationen. Wenn wir diese Methode aufrufen, sind auch die Ausgabeergebnisse unterschiedlich.

  1. Schnittstellen verwenden

Es gibt kein Konzept einer dedizierten Schnittstelle in JavaScript, aber wir können eine Schnittstelle implementieren, indem wir eine Reihe von Methoden definieren Konzept umgesetzt werden muss. Wenn ein Objekt diesen Methodensatz implementiert, können wir davon ausgehen, dass es diese Schnittstelle implementiert.

Das Folgende ist ein Beispiel:

class Shape {
  draw() {
    console.log('Shape is drawing.')
  }
}

class Circle extends Shape {
  draw() {
    console.log('Circle is drawing.')
  }
}

class Rectangle extends Shape {
  draw() {
    console.log('Rectangle is drawing.')
  }
}

let circle = new Circle()
let rectangle = new Rectangle()

function drawShape(shape) {
  if (shape.draw instanceof Function) {
    shape.draw()
  }
}

drawShape(circle) // 输出 "Circle is drawing."
drawShape(rectangle) // 输出 "Rectangle is drawing."
Nach dem Login kopieren

Im obigen Beispiel haben wir eine übergeordnete Klasse „Shape“ und zwei Unterklassen „Circle“ und „Rechteck“ erstellt. Sie alle implementieren die Methode draw(). Dann definieren wir eine Funktion drawShape(), die eine Parameterform empfängt, und wenn die Form die Methode draw() implementiert, rufen wir sie auf.

Fazit

Die oben genannten sind zwei Möglichkeiten, Polymorphismus durch Vererbung und Schnittstellen zu erreichen und so die Flexibilität und Verfügbarkeit des Programms zu verbessern. In der tatsächlichen Entwicklung können wir je nach Situation den geeigneten Weg zur Implementierung des Polymorphismus wählen.

Das obige ist der detaillierte Inhalt vonSo implementieren Sie Polymorphismus in JavaScript. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage