Maison > interface Web > js tutoriel > Maîtriser les cours JavaScript : un guide complet de la POO moderne

Maîtriser les cours JavaScript : un guide complet de la POO moderne

Linda Hamilton
Libérer: 2024-12-27 05:58:17
original
615 Les gens l'ont consulté

Mastering JavaScript Classes: A Complete Guide to Modern OOP

Comprendre les classes JavaScript

Les classes JavaScript sont un sucre syntaxique par rapport à son système d'héritage prototypique. Introduites dans ES6, les classes offrent un moyen clair et structuré de définir des objets et de travailler avec l'héritage en JavaScript, rendant le code plus lisible et organisé.


Définir une classe

Vous pouvez définir une classe en utilisant le mot-clé class.

Exemple :

class Person {
  constructor(name, age) {
    this.name = name;
    this.age = age;
  }

  greet() {
    console.log(`Hello, my name is ${this.name} and I am ${this.age} years old.`);
  }
}

const person1 = new Person("Alice", 25);
person1.greet(); // Hello, my name is Alice and I am 25 years old.
Copier après la connexion

Principales caractéristiques des cours

  1. Méthode Constructeur : Le constructeur est une méthode spéciale pour initialiser de nouveaux objets. Il est appelé automatiquement lorsqu'une nouvelle instance de la classe est créée.

Exemple :

   class Car {
     constructor(brand) {
       this.brand = brand;
     }
   }

   const myCar = new Car("Toyota");
   console.log(myCar.brand); // Toyota
Copier après la connexion
  1. Méthodes : Les fonctions définies dans une classe sont appelées méthodes.

Exemple :

   class Animal {
     sound() {
       console.log("Animal makes a sound");
     }
   }

   const dog = new Animal();
   dog.sound(); // Animal makes a sound
Copier après la connexion
  1. Méthodes statiques : Les méthodes définies avec le mot-clé static appartiennent à la classe elle-même, et non aux instances de la classe.

Exemple :

   class MathUtils {
     static add(a, b) {
       return a + b;
     }
   }

   console.log(MathUtils.add(3, 5)); // 8
Copier après la connexion
  1. Getters et Setters : Méthodes spéciales pour accéder et modifier les propriétés.

Exemple :

   class Rectangle {
     constructor(width, height) {
       this.width = width;
       this.height = height;
     }

     get area() {
       return this.width * this.height;
     }
   }

   const rect = new Rectangle(10, 5);
   console.log(rect.area); // 50
Copier après la connexion

Héritage dans les classes

L'héritage permet à une classe d'acquérir des propriétés et des méthodes d'une autre classe à l'aide du mot-clé extends.

Exemple :

class Animal {
  constructor(name) {
    this.name = name;
  }

  speak() {
    console.log(`${this.name} makes a sound.`);
  }
}

class Dog extends Animal {
  speak() {
    console.log(`${this.name} barks.`);
  }
}

const dog = new Dog("Rex");
dog.speak(); // Rex barks.
Copier après la connexion

Champs et méthodes privés

Les champs et méthodes privés, introduits dans ES2022, commencent par un # et ne sont pas accessibles en dehors de la classe.

Exemple :

class BankAccount {
  #balance;

  constructor(initialBalance) {
    this.#balance = initialBalance;
  }

  deposit(amount) {
    this.#balance += amount;
    console.log(`Deposited: ${amount}`);
  }

  getBalance() {
    return this.#balance;
  }
}

const account = new BankAccount(100);
account.deposit(50); // Deposited: 50
console.log(account.getBalance()); // 150
// console.log(account.#balance); // Error: Private field '#balance' must be declared in an enclosing class
Copier après la connexion

Expressions de classe

Les classes peuvent également être définies comme des expressions et affectées à des variables.

Exemple :

const Rectangle = class {
  constructor(width, height) {
    this.width = width;
    this.height = height;
  }

  getArea() {
    return this.width * this.height;
  }
};

const rect = new Rectangle(10, 5);
console.log(rect.getArea()); // 50
Copier après la connexion

Mélange avec des Prototypes

Bien que les classes soient du sucre syntaxique, vous pouvez toujours les combiner avec l'héritage basé sur un prototype de JavaScript.

Exemple :

class Person {}
Person.prototype.sayHello = function () {
  console.log("Hello!");
};

const person = new Person();
person.sayHello(); // Hello!
Copier après la connexion

Bonnes pratiques avec les cours

  1. Encapsulation :

    Utilisez des champs privés pour protéger les données sensibles.

  2. Réutilisabilité :

    Tirez parti de l'héritage pour réutiliser le code dans plusieurs classes.

  3. Éviter les complications excessives :

    Utilisez les cours uniquement lorsque cela est nécessaire. Des objets ou des fonctions simples peuvent suffire pour de petites tâches.

  4. Cohérence :

    Suivez les conventions de dénomination des méthodes et des propriétés pour plus de lisibilité.


Conclusion

Les classes JavaScript offrent un moyen propre et efficace de gérer la programmation orientée objet en JavaScript. Avec des fonctionnalités telles que l'héritage, les méthodes statiques, les champs privés et l'encapsulation, ils offrent des outils puissants pour structurer et gérer le code, facilitant ainsi la création d'applications évolutives et maintenables.

Bonjour, je m'appelle Abhay Singh Kathayat !
Je suis un développeur full-stack avec une expertise dans les technologies front-end et back-end. Je travaille avec une variété de langages et de frameworks de programmation pour créer des applications efficaces, évolutives et conviviales.
N'hésitez pas à me contacter à mon e-mail professionnel : kaashshorts28@gmail.com.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:dev.to
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal