Maison >interface Web >js tutoriel >Héritage JavaScript : Object.create vs new : lequel vous convient le mieux ?
Héritage JavaScript : dévoilement du standard Defacto
Malgré de nombreux articles traitant de l'héritage JavaScript, la confusion surgit souvent en raison de la pléthore d'approches disponibles. Pour clarifier ce sujet énigmatique, nous explorons les méthodes les plus acceptées et fournissons des conseils adaptés à votre scénario spécifique.
Choisir le mécanisme d'héritage approprié
Comprendre la distinction entre new et Object.create sont cruciaux pour sélectionner la stratégie d'héritage optimale. Bien que les deux techniques facilitent la création d’objets, elles répondent à des objectifs différents. Object.create génère un nouvel objet qui hérite d'un autre, tandis que new invoque en outre une fonction constructeur.
Application à votre cas d'utilisation
Votre objectif est d'établir un objet de base nommé Model avec les sous-classes extensibles RestModel et LocalStorageModel. Dans ce scénario, Object.create apparaît comme la méthode préférée. Cette approche correspond à votre intention de créer une hiérarchie d'héritage de prototype sans invoquer le constructeur Model.
<br>RestModel.prototype = Object.create(Model.prototype);<br></ pre></p> <p><strong>Invoquer un constructeur dans Sous-classes</strong></p> <p>Si l'appel du constructeur Model pour RestModels est souhaité, cela n'est pas accompli par héritage. Au lieu de cela, <strong>call()</strong> ou <strong>apply()</strong> fournissent les moyens de déclencher l'exécution du constructeur.</p> <p><pre class="brush:php;toolbar:false"><br>function RestModel() {</p> <pre class="brush:php;toolbar:false">Model.call(this); // Apply Model's constructor on the new object ...
}
Par En comprenant ces concepts, vous pouvez implémenter en toute confiance l'héritage en JavaScript, offrant ainsi à vos applications la flexibilité et l'extensibilité dont elles ont besoin.
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!