Maison interface Web js tutoriel Explication détaillée des cas d'utilisation de l'héritage d'objets JS

Explication détaillée des cas d'utilisation de l'héritage d'objets JS

Jun 04, 2018 am 10:47 AM
javascript 案例 详解

Cette fois, je vais vous apporter une explication détaillée des cas d'utilisation de l'héritage d'objets JS. Quelles sont les précautions à prendre pour utiliser l'héritage d'objets JS ? Voici des cas pratiques, jetons un coup d'œil.

Modifier des objets que vous ne possédez pas est une bonne solution à certains problèmes. Dans un état « bénin », cela ne se produit généralement pas ; cela peut se produire parce que le développeur a rencontré un problème et l'a ensuite résolu en modifiant l'objet. Néanmoins, il existe toujours plusieurs solutions à un problème connu. Une grande partie des connaissances en informatique a évolué pour résoudre des problèmes difficiles dans des environnements linguistiques typés statiquement, tels que Java. Il peut exister des méthodes, appelées modèles de conception, qui ne modifient pas directement ces objets mais les étendent.

En dehors de JS, la forme d'extension d'objet la plus populaire est l'héritage. Si un type d'objet fait déjà la plupart de ce que vous voulez, héritez-en, puis ajoutez quelques fonctionnalités. Il existe deux formes de base dans JS : l'héritage basé sur les objets et l'héritage basé sur le type.

En JS, l'héritage a encore de grosses limites. Premièrement, vous ne pouvez pas hériter des objets DOM ou BOM. Deuxièmement, en raison de la relation complexe entre l'index du tableau et la propriété length, l'héritage d'Array ne fonctionnera pas correctement.

Héritage basé sur les objets

Dans l'héritage basé sur les objets, souvent appelé héritage prototypique, un objet hérite d'un autre objet sans appeler le constructeur. La méthode ES5 Object.create() est le moyen le plus simple d'implémenter ce type d'héritage. Par exemple :

var person = {  name: 'Nicholas',  sayName: function () {    console.log(this.name);
  }
};var myPerson = Object.create(person);
myPerson.sayName(); // "Nicholas"
Copier après la connexion

Cet exemple crée un nouvel objet myPerson, qui hérite de person. Cette méthode d'héritage est comme le prototype de myPerson étant défini sur person. Dès lors, myPerson peut accéder aux attributs et méthodes de person sans avoir à redéfinir la variable du même nom sur un nouvel objet. Par exemple, redéfinir myPerson.sayName() coupera automatiquement l'accès à person.sayName() :

myPerson.sayName = function () {  console.log('Anonymous');
};
myPerson.sayName(); // "Anonymous"person.sayName(); // "Nicholas"
Copier après la connexion

La méthode Object.create() peut spécifier un deuxième paramètre, les propriétés de l'objet paramètre et Les méthodes seront ajoutées au nouvel objet. Par exemple :

var myPerson = Object.create(person, {  name: {    value: 'Greg'
  }
});
myPerson.sayName(); // "Greg"person.sayName(); // "Nicholas"
Copier après la connexion

L'objet myPerson créé dans cet exemple a sa propre valeur d'attribut name, donc appeler sayName() affiche "Greg" au lieu de "Nicholas".

Une fois qu'un nouvel objet est créé de cette manière, le nouvel objet est totalement libre de le modifier. Après tout, vous êtes le propriétaire de l'objet et vous pouvez ajouter des méthodes, écraser des méthodes existantes ou même supprimer des méthodes (ou empêcher leur accès) dans votre projet.

L'héritage basé sur le type

L'héritage basé sur le type fonctionne de la même manière que l'héritage basé sur l'objet. Il hérite d'un objet existant. L'héritage dépend ici du prototype. Par conséquent, l’héritage basé sur le type est implémenté via des constructeurs et non des objets. Cela signifie qu'il faut accéder au constructeur de l'objet hérité. Comparé aux types natifs dans JS, l'héritage basé sur les types est plus approprié lorsque les développeurs définissent des constructeurs. Dans le même temps, l’héritage basé sur le type nécessite généralement deux étapes : d’abord l’héritage du prototype, puis l’héritage du constructeur ; L'héritage du constructeur consiste à transmettre l'objet nouvellement créé comme valeur lors de l'appel du constructeur de la super classe. Par exemple :

function Person (name) {  this.name = name;
}function Author (name) {
  Person.call(this, name); // 继承构造器}
Author.prototype = new Person();
Copier après la connexion

Dans ce code, le type Auteur hérite de Personne. Le nom de l'attribut est en fait géré par la classe Person, donc Person.call(this, name) permet au constructeur Person de continuer à définir l'attribut. Le constructeur Person est exécuté sur celui-ci, qui pointe vers un objet Author, donc le nom final est défini sur cet objet Author.

Par rapport à l'héritage basé sur les objets, l'héritage basé sur le type est plus flexible lors de la création de nouveaux objets. La définition d'un type vous permet de créer plusieurs objets d'instance, qui héritent tous d'une superclasse commune. Le nouveau type doit définir clairement les propriétés et les méthodes qu'il doit utiliser, et elles doivent être complètement différentes de celles de la superclasse.

Je pense que vous maîtrisez la méthode après avoir lu le cas dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le site Web chinois de php !

Lecture recommandée :

Comment éviter les comparaisons nulles dans le développement Web

Pourquoi devez-vous éviter d'utiliser des variables globales dans développement web

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

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)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

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)

Explication détaillée de l'obtention des droits d'administrateur dans Win11 Explication détaillée de l'obtention des droits d'administrateur dans Win11 Mar 08, 2024 pm 03:06 PM

Le système d'exploitation Windows est l'un des systèmes d'exploitation les plus populaires au monde et sa nouvelle version Win11 a beaucoup attiré l'attention. Dans le système Win11, l'obtention des droits d'administrateur est une opération importante. Les droits d'administrateur permettent aux utilisateurs d'effectuer davantage d'opérations et de paramètres sur le système. Cet article présentera en détail comment obtenir les autorisations d'administrateur dans le système Win11 et comment gérer efficacement les autorisations. Dans le système Win11, les droits d'administrateur sont divisés en deux types : administrateur local et administrateur de domaine. Un administrateur local dispose de tous les droits d'administration sur l'ordinateur local

Explication détaillée du fonctionnement de la division dans Oracle SQL Explication détaillée du fonctionnement de la division dans Oracle SQL Mar 10, 2024 am 09:51 AM

Explication détaillée de l'opération de division dans OracleSQL Dans OracleSQL, l'opération de division est une opération mathématique courante et importante, utilisée pour calculer le résultat de la division de deux nombres. La division est souvent utilisée dans les requêtes de bases de données. Comprendre le fonctionnement de la division et son utilisation dans OracleSQL est donc l'une des compétences essentielles des développeurs de bases de données. Cet article discutera en détail des connaissances pertinentes sur les opérations de division dans OracleSQL et fournira des exemples de code spécifiques pour référence aux lecteurs. 1. Opération de division dans OracleSQL

Explication détaillée du rôle et de l'utilisation de l'opérateur modulo PHP Explication détaillée du rôle et de l'utilisation de l'opérateur modulo PHP Mar 19, 2024 pm 04:33 PM

L'opérateur modulo (%) en PHP est utilisé pour obtenir le reste de la division de deux nombres. Dans cet article, nous discuterons en détail du rôle et de l'utilisation de l'opérateur modulo et fournirons des exemples de code spécifiques pour aider les lecteurs à mieux comprendre. 1. Le rôle de l'opérateur modulo En mathématiques, lorsqu'on divise un entier par un autre entier, on obtient un quotient et un reste. Par exemple, lorsque l’on divise 10 par 3, le quotient est 3 et le reste est 1. L'opérateur modulo est utilisé pour obtenir ce reste. 2. Utilisation de l'opérateur modulo En PHP, utilisez le symbole % pour représenter le module

Explication détaillée de la fonction d'appel système Linux system() Explication détaillée de la fonction d'appel système Linux system() Feb 22, 2024 pm 08:21 PM

Explication détaillée de la fonction d'appel système Linux system() L'appel système est une partie très importante du système d'exploitation Linux. Il fournit un moyen d'interagir avec le noyau système. Parmi elles, la fonction system() est l’une des fonctions d’appel système couramment utilisées. Cet article présentera en détail l’utilisation de la fonction system() et fournira des exemples de code correspondants. Concepts de base des appels système Les appels système sont un moyen permettant aux programmes utilisateur d'interagir avec le noyau du système d'exploitation. Les programmes utilisateur demandent au système d'exploitation en appelant des fonctions d'appel système

Explication détaillée de la commande Linux curl Explication détaillée de la commande Linux curl Feb 21, 2024 pm 10:33 PM

Explication détaillée de la commande curl de Linux Résumé : curl est un puissant outil de ligne de commande utilisé pour la communication de données avec le serveur. Cet article présentera l'utilisation de base de la commande curl et fournira des exemples de code réels pour aider les lecteurs à mieux comprendre et appliquer la commande. 1. Qu’est-ce que la boucle ? curl est un outil de ligne de commande utilisé pour envoyer et recevoir diverses requêtes réseau. Il prend en charge plusieurs protocoles, tels que HTTP, FTP, TELNET, etc., et fournit des fonctions riches, telles que le téléchargement de fichiers, le téléchargement de fichiers, la transmission de données, le proxy.

Tutoriel JavaScript simple : Comment obtenir le code d'état HTTP Tutoriel JavaScript simple : Comment obtenir le code d'état HTTP Jan 05, 2024 pm 06:08 PM

Tutoriel JavaScript : Comment obtenir le code d'état HTTP, des exemples de code spécifiques sont requis Préface : Dans le développement Web, l'interaction des données avec le serveur est souvent impliquée. Lors de la communication avec le serveur, nous devons souvent obtenir le code d'état HTTP renvoyé pour déterminer si l'opération a réussi et effectuer le traitement correspondant en fonction de différents codes d'état. Cet article vous apprendra comment utiliser JavaScript pour obtenir des codes d'état HTTP et fournira quelques exemples de codes pratiques. Utilisation de XMLHttpRequest

Analyse détaillée du parcours d'apprentissage du langage C Analyse détaillée du parcours d'apprentissage du langage C Feb 18, 2024 am 10:38 AM

En tant que langage de programmation largement utilisé dans le domaine du développement de logiciels, le langage C est le premier choix de nombreux programmeurs débutants. L'apprentissage du langage C peut non seulement nous aider à acquérir des connaissances de base en programmation, mais également à améliorer nos capacités de résolution de problèmes et de réflexion. Cet article présentera en détail une feuille de route d'apprentissage du langage C pour aider les débutants à mieux planifier leur processus d'apprentissage. 1. Apprendre la grammaire de base Avant de commencer à apprendre le langage C, nous devons d'abord comprendre les règles de grammaire de base du langage C. Cela inclut les variables et les types de données, les opérateurs, les instructions de contrôle (telles que les instructions if,

Explication détaillée de la méthode de requête de version numpy Explication détaillée de la méthode de requête de version numpy Jan 19, 2024 am 08:20 AM

Numpy est une bibliothèque de calcul scientifique Python qui fournit une multitude de fonctions et d'outils d'opération de tableau. Lors de la mise à niveau de la version Numpy, vous devez interroger la version actuelle pour garantir la compatibilité. Cet article présentera en détail la méthode de requête de version Numpy et fournira des exemples de code spécifiques. Méthode 1 : utilisez le code Python pour interroger la version Numpy Vous pouvez facilement interroger la version Numpy à l'aide du code Python. Voici la méthode d'implémentation et un exemple de code : importnumpyasnpprint(np.

See all articles