Maison interface Web js tutoriel Comprendre les compétences d'héritage d'objet javascript_javascript

Comprendre les compétences d'héritage d'objet javascript_javascript

May 16, 2016 pm 03:05 PM

Commençons par une étude plus approfondie : qu'est-ce que l'héritage d'objets JavaScript ?

Par exemple, nous avons un constructeur pour l'objet "animal".

  function animal() {
    this.type = '动物';
  }
Copier après la connexion

Il existe également un constructeur pour l'objet "cat".

  function cat(name,color) {
    this.name = name;
    this.color = color;
  }
Copier après la connexion

Nous savons que les chats sont aussi des animaux. Si cet objet chat veut hériter des attributs de l'objet animal, que devons-nous faire ?

Reliure du constructeur
L'utilisation de la liaison constructeur est la méthode la plus simple. Utilisez simplement call ou apply pour lier l'objet parent à l'objet self.

 function cat(name,color) {
    animal.apply(this,arguments);
    this.name = name;
    this.color = color;
  }
  var cat1 = new cat("haha", 'red');
  console.log(cat1.type); //动物
Copier après la connexion

Cependant, cette méthode est relativement rare.

Copier l'héritage
Si vous copiez toutes les propriétés et méthodes de l'objet parent dans l'objet enfant, l'héritage peut également être obtenu.

  function extend(Child, Parent) {
    var p = Parent.prototype;
    var c = Child.prototype;
    for (var i in p) {
      c[i] = p[i];
      }
    c.uber = p;   //桥梁作用
  }
Copier après la connexion

Comment utiliser :

 extend(cat, animal);
  var cat1 = new cat("haha","red");
  alert(cat1.type);   // 动物
Copier après la connexion

Héritage du prototype (prototype)
Par rapport à la liaison directe ci-dessus, la méthode d'héritage du prototype est plus courante concernant le prototype, je l'ai brièvement résumée moi-même.

Chaque fonction a un attribut prototype, qui est une référence à un objet Lorsque vous utilisez le mot-clé new pour créer une nouvelle instance, l'objet instance héritera des propriétés et des méthodes de l'objet prototype.

En d'autres termes, si l'attribut prototype du constructeur "cat" pointe vers une instance "animal", alors lorsque l'instance d'objet "cat" est créée, les propriétés et méthodes de l'objet "animal" seront héritées.

Instance héritée

 cat.prototype = new animal();
  cat.prototype.constructor = cat;
  var cat1 = new cat("haha","red");
  console.log(cat1.constructor == cat);  //true
  console.log(cat1.type); // 动物
Copier après la connexion

1. Dans la première ligne du code, nous pointons l'objet prototype de la fonction cat vers une instance de l'objet animal (qui contient l'attribut type de animal).

2. Que signifie la deuxième ligne de code ?

1), d'abord, si nous n'avons pas ajouté cette ligne de code, exécutez

cat.prototype = nouvel animal();
console.log(cat.prototype.constructor == animal); //true
En d’autres termes, chaque objet prototype possède en réalité un attribut constructeur pointant vers son constructeur.

2), regardons le code ci-dessous

 cat.prototype = new animal();
  var cat1 = new cat("haha", 'red');
  console.log(cat1.constructor == animal);  //true
Copier après la connexion

D'après ce qui précède, nous voyons que le constructeur de l'instance cat1 est animal, donc c'est évidemment faux. . . cat1 est évidemment généré par new cat(), nous devrions donc le corriger manuellement. La valeur du constructeur de l'objet cat.prototype est remplacée par cat.

3), C'est donc quelque chose auquel nous devons prêter attention. Si nous remplaçons l'objet prototype, nous devons corriger manuellement l'attribut constructeur de l'objet prototype.

o.prototype = {};
o.prototype.constructor = o;
Hériter directement du prototype
Puisque dans les objets animaux, les attributs immuables peuvent être écrits directement dans animal.prototype. Ensuite, laissez directement cat.prototype pointer vers animal.prototype pour obtenir l'héritage.

Maintenant, nous réécrivons d'abord l'objet animal comme :

  function animal() {
  }
  animal.prototype.type = '动物';
Copier après la connexion

Ensuite, implémentez l'héritage :

 cat.prototype = animal.prototype;
  cat.prototype.constructor = cat;
  var cat1 = new cat("haha","red");
  console.log(cat1.type); // 动物
Copier après la connexion

Par rapport à la méthode précédente, cette méthode est plus efficace (aucune instance animale n'est créée) et permet de gagner de la place. Mais est-ce la bonne chose à faire ? La réponse est incorrecte, continuons à chercher.

cat.prototype = animal.prototype;
Cette ligne de code fait que cat.prototype et animal.prototype pointent vers le même objet, donc si un certain attribut de cat.prototype est modifié, cela sera reflété dans animal.prototype, ce qui n'est évidemment pas ce que nous voulons voir.

Par exemple, si on court :

console.log(animal.prototype.constructor == animal) //false
Le résultat est faux, pourquoi ? cat.prototype.constructor = cat; Cette ligne modifiera également l'attribut constructeur de animal.prototype.

Utiliser des objets vides comme intermédiaires

  var F = function(){};
  F.prototype = animal.prototype;
  cat.prototype = new F();
  cat.prototype.constructor = cat;
Copier après la connexion

En combinant les deux méthodes ci-dessus, comme F est un objet vide, il ne prend presque pas de mémoire. Pour le moment, la modification de l’objet prototype du chat n’affectera pas l’objet prototype de l’animal.

console.log(animal.prototype.constructor == animal); // vrai
Ensuite, nous encapsulons la méthode ci-dessus :

  function extend(Child, Parent) {
    var F = function(){};
    F.prototype = Parent.prototype;
    Child.prototype = new F();
    Child.prototype.constructor = Child;
    Child.uber = Parent.prototype;
  }
Copier après la connexion

Lors de son utilisation, la méthode est la suivante :

 extend(cat,animal);
  var cat1 = new cat("haha","red");
  console.log(cat1.type); // 动物
Copier après la connexion

Child.uber = Parent.prototype; Cette ligne de code agit comme un pont, permettant à l'attribut uber de l'objet enfant de pointer directement vers l'attribut prototype de l'objet parent. Cela équivaut à ouvrir un canal appelé uber sur. l'auto-objet, permettant aux instances de l'objet enfant de pouvoir utiliser toutes les propriétés et méthodes de l'objet parent.

Ce qui précède est ma compréhension de l'héritage des objets JavaScript. J'espère que cela pourra vous aider plus ou moins. Merci d'avoir lu.

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

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)

Remplacer les caractères de chaîne en javascript Remplacer les caractères de chaîne en javascript Mar 11, 2025 am 12:07 AM

Explication détaillée de la méthode de remplacement de la chaîne JavaScript et de la FAQ Cet article explorera deux façons de remplacer les caractères de chaîne dans JavaScript: le code JavaScript interne et le HTML interne pour les pages Web. Remplacer la chaîne dans le code JavaScript Le moyen le plus direct consiste à utiliser la méthode Remplace (): str = str.replace ("trouver", "remplacer"); Cette méthode remplace uniquement la première correspondance. Pour remplacer toutes les correspondances, utilisez une expression régulière et ajoutez le drapeau global G: str = str.replace (/ fi

8 Superbes plugins de mise en page JQuery Page 8 Superbes plugins de mise en page JQuery Page Mar 06, 2025 am 12:48 AM

Tirez parti de jQuery pour les dispositions de page Web sans effort: 8 plugins essentiels JQuery simplifie considérablement la mise en page de la page Web. Cet article met en évidence huit puissants plugins jQuery qui rationalisent le processus, particulièrement utile pour la création de sites Web manuels

Créez vos propres applications Web Ajax Créez vos propres applications Web Ajax Mar 09, 2025 am 12:11 AM

Vous voici donc, prêt à tout savoir sur cette chose appelée Ajax. Mais qu'est-ce que c'est exactement? Le terme Ajax fait référence à un regroupement lâche de technologies utilisées pour créer un contenu Web interactif dynamique. Le terme Ajax, inventé à l'origine par Jesse J

10 JQUERY FUN ET PLIGINS DE GAMES 10 JQUERY FUN ET PLIGINS DE GAMES Mar 08, 2025 am 12:42 AM

10 plugins de jeu JQuery amusants pour rendre votre site Web plus attrayant et améliorer l'adhérence des utilisateurs! Bien que Flash soit toujours le meilleur logiciel pour développer des jeux Web occasionnels, JQuery peut également créer des effets surprenants, et bien qu'il ne soit pas comparable aux jeux Flash Pure Action, dans certains cas, vous pouvez également vous amuser inattendu dans votre navigateur. jeu jquery tic toe Le "Hello World" de la programmation de jeux a désormais une version jQuery. Code source JQUERY Crazy Word Composition Game Il s'agit d'un jeu de remplissage, et il peut produire des résultats étranges en raison de ne pas connaître le contexte du mot. Code source Jeu de balayage de la mine jQuery

Comment créer et publier mes propres bibliothèques JavaScript? Comment créer et publier mes propres bibliothèques JavaScript? Mar 18, 2025 pm 03:12 PM

L'article discute de la création, de la publication et du maintien des bibliothèques JavaScript, en se concentrant sur la planification, le développement, les tests, la documentation et les stratégies de promotion.

Chargez le contenu de la boîte dynamiquement à l'aide de AJAX Chargez le contenu de la boîte dynamiquement à l'aide de AJAX Mar 06, 2025 am 01:07 AM

Ce didacticiel montre la création de boîtes de page dynamiques chargées via AJAX, permettant un actualisation instantanée sans rechargement de page pleine. Il exploite JQuery et JavaScript. Considérez-le comme un chargeur de boîtes de contenu de style Facebook personnalisé. Concepts clés: Ajax et jQuery

Tutoriel JQuery Parallax - Contexte d'en-tête animé Tutoriel JQuery Parallax - Contexte d'en-tête animé Mar 08, 2025 am 12:39 AM

Ce tutoriel montre comment créer un effet de fond de parallaxe captivant à l'aide de jQuery. Nous allons construire une bannière d'en-tête avec des images en couches qui créent une profondeur visuelle étonnante. Le plugin mis à jour fonctionne avec jQuery 1.6.4 et plus tard. Télécharger le

Comment rédiger une bibliothèque de session sans cookie pour JavaScript Comment rédiger une bibliothèque de session sans cookie pour JavaScript Mar 06, 2025 am 01:18 AM

Cette bibliothèque JavaScript exploite la propriété Window.Name pour gérer les données de session sans compter sur les cookies. Il offre une solution robuste pour stocker et récupérer des variables de session à travers les navigateurs. La bibliothèque fournit trois méthodes de base: Session

See all articles