Table des matières
Quelles sont les trois méthodes de définition d'une classe en JavaScript
Maison interface Web Questions et réponses frontales Quelles sont les trois méthodes pour définir une classe en javascript

Quelles sont les trois méthodes pour définir une classe en javascript

Feb 21, 2022 pm 05:13 PM
html javascript 前端

Trois façons de définir une classe en JavaScript : 1. Utilisez le constructeur pour définir la classe, la syntaxe est "function name(){this.name=value;}" 2. Utilisez le "Object.create()" ; 3. , utilisez la méthode "createNew()" pour définir la classe.

Quelles sont les trois méthodes pour définir une classe en javascript

L'environnement d'exploitation de ce tutoriel : système Windows 10, JavaScript version 1.8.5, ordinateur Dell G3.

Quelles sont les trois méthodes de définition d'une classe en JavaScript

En programmation orientée objet, une classe est un modèle pour un objet, qui définit les propriétés et méthodes communes au même groupe d'objets (également appelés "instances") .

Le langage JavaScript ne prend pas en charge les "classes", mais vous pouvez utiliser certaines solutions de contournement pour simuler des "classes".

1. Méthode constructeur

C'est une méthode classique et une méthode incontournable dans les manuels scolaires. Il utilise un constructeur pour simuler une "classe" et utilise le mot-clé this en interne pour faire référence à l'objet instance.

function Cat(){
  this.name = "大毛";
}
Copier après la connexion

Lors de la génération d'une instance, utilisez le nouveau mot-clé.

var cat1 = new Cat();
alert(cat1.name);   //大毛
Copier après la connexion

Les attributs et méthodes de la classe peuvent également être définis sur l'objet prototype du constructeur.

Cat.prototype.makeSound = function(){
  alert("喵喵喵");
}
Copier après la connexion

Pour une introduction détaillée à cette méthode, veuillez consulter la série d'articles "Programmation orientée objet JavaScript", je n'entrerai pas dans les détails ici. Son principal inconvénient est qu'il est compliqué à enseigner, qu'il utilise ceci et des prototypes, et qu'il est très laborieux à écrire et à lire.

2. Méthode Object.create()

Afin de résoudre les lacunes de la "méthode constructeur" et de générer des objets plus facilement, la cinquième édition de la norme internationale pour JavaScript ECMAScript (la troisième édition est actuellement populaire), une nouvelle méthode Object.create() est proposée.

Avec cette méthode, "classe" est un objet, pas une fonction.

var Cat = {
  name: "大毛",
  makeSound: function(){
    alert("喵喵喵");
  }
};
Copier après la connexion

Ensuite, utilisez directement Object.create() pour générer l'instance sans utiliser new.

var cat1 = Object.create(Cat);
alert(cat1.name);   //大毛
cat1.makeSound();   //喵喵喵
Copier après la connexion

Actuellement, les dernières versions de tous les principaux navigateurs (y compris IE9) ont déployé cette méthode. Si vous rencontrez un ancien navigateur, vous pouvez utiliser le code suivant pour le déployer vous-même.

if(!Object.create){
  Object.create = function(o){
    function F(){};
    F.prototype = o;
    return new F();
  }
}
Copier après la connexion

Cette méthode est plus simple que la "méthode constructeur", mais elle ne peut pas implémenter de propriétés privées et de méthodes privées, ni partager des données entre des objets d'instance, et la simulation de "classes" n'est pas assez complète.

3. Méthode minimaliste

Le programmeur néerlandais Gabor de Mooij a proposé une nouvelle méthode meilleure que Object.create(). C'est aussi la méthode que je recommande.

3.1 Encapsulation

Cette méthode ne s'applique pas à ceci et au prototype, et le code est très simple à déployer, c'est probablement pourquoi on l'appelle la "méthode minimaliste".

Tout d'abord, il utilise également un objet pour simuler une "classe". Dans cette classe, définissez un constructeur caeateNew() pour générer des instances.

var Cat = {
  createNew: function(){
    //some code here
  }
};
Copier après la connexion

Ensuite, dans carateNew(), définissez un objet instance et utilisez cet objet instance comme valeur de retour.

var Cat = {
  createNew: function(){
    var cat = {};
    cat.name = "大毛";
    car.makeSound = function(){
      alert("喵喵喵");
    };
  }
};
Copier après la connexion

Lors de son utilisation, appelez la méthode createNew() pour obtenir l'objet instance.

var cat1 = Cat.createNew();
cat1.makeSound();   //喵喵喵
Copier après la connexion

L'avantage de cette méthode est qu'elle est facile à comprendre, qu'elle a une structure claire et élégante et qu'elle est conforme à la construction traditionnelle de « programmation orientée objet », de sorte que les fonctionnalités suivantes peuvent être facilement déployées.

Recommandations associées : Tutoriel d'apprentissage Javascript

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!

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Bordure de tableau en HTML Bordure de tableau en HTML Sep 04, 2024 pm 04:49 PM

Guide de la bordure de tableau en HTML. Nous discutons ici de plusieurs façons de définir une bordure de tableau avec des exemples de bordure de tableau en HTML.

Marge gauche HTML Marge gauche HTML Sep 04, 2024 pm 04:48 PM

Guide de la marge HTML gauche. Nous discutons ici d'un bref aperçu de la marge gauche HTML et de ses exemples ainsi que de son implémentation de code.

Tableau imbriqué en HTML Tableau imbriqué en HTML Sep 04, 2024 pm 04:49 PM

Ceci est un guide des tableaux imbriqués en HTML. Nous discutons ici de la façon de créer un tableau dans le tableau ainsi que des exemples respectifs.

Disposition du tableau HTML Disposition du tableau HTML Sep 04, 2024 pm 04:54 PM

Guide de mise en page des tableaux HTML. Nous discutons ici des valeurs de la mise en page des tableaux HTML ainsi que des exemples et des résultats en détail.

Espace réservé d'entrée HTML Espace réservé d'entrée HTML Sep 04, 2024 pm 04:54 PM

Guide de l'espace réservé de saisie HTML. Nous discutons ici des exemples d'espace réservé d'entrée HTML ainsi que des codes et des sorties.

Déplacer du texte en HTML Déplacer du texte en HTML Sep 04, 2024 pm 04:45 PM

Guide pour déplacer du texte en HTML. Nous discutons ici d'une introduction, du fonctionnement des balises de sélection avec la syntaxe et des exemples à implémenter.

Liste ordonnée HTML Liste ordonnée HTML Sep 04, 2024 pm 04:43 PM

Guide de la liste ordonnée HTML. Ici, nous discutons également de l'introduction de la liste et des types HTML ordonnés ainsi que de leur exemple respectivement.

Bouton HTML onclick Bouton HTML onclick Sep 04, 2024 pm 04:49 PM

Guide du bouton HTML onclick. Nous discutons ici de leur introduction, de leur fonctionnement, des exemples et de l'événement onclick dans divers événements respectivement.

See all articles