Maison >interface Web >js tutoriel >Comment le « nouveau » mot-clé fonctionne-t-il en JavaScript pour créer des objets et implémenter l'héritage ?
Explorer le « nouveau » mot-clé en JavaScript
Comprendre le « nouveau » mot-clé
En JavaScript, le mot-clé « nouveau » joue un rôle central dans la création d'objets et dans le concept d'héritage. Malgré la réputation de JavaScript en tant que langage non orienté objet, il introduit une approche unique de la programmation basée sur les objets via le mot-clé « nouveau ».
Objectif du mot-clé « nouveau »
Le mot-clé « nouveau » a plusieurs responsabilités clés :
Comprendre les propriétés [[prototype]] et « prototype »
Exemple de création d'objet avec 'nouveau'
function ObjMaker() { this.a = 'first'; } // 'ObjMaker' is the constructor function ObjMaker.prototype.b = 'second'; // 'ObjMaker.prototype' is the prototype object obj1 = new ObjMaker(); // 'new' creates a new 'obj1' object, assigns the prototype, and executes 'ObjMaker' obj1.a; // 'first' obj1.b; // 'second' // 'obj1' inherits 'b' from 'ObjMaker.prototype' while still accessing its own property 'a'
Hiérarchie de l'héritage avec le « nouveau »
À travers le Mot-clé « nouveau », JavaScript permet un modèle d'héritage basé sur un prototype. En définissant la propriété [[prototype]], les objets héritent des propriétés et des méthodes du prototype de leur constructeur. Cela permet la création de sous-classes qui étendent les classes existantes, comme ceci :
function SubObjMaker() {} SubObjMaker.prototype = new ObjMaker(); // deprecated, use Object.create() now SubObjMaker.prototype.c = 'third'; obj2 = new SubObjMaker(); obj2.c; // 'third' obj2.b; // 'second' obj2.a; // 'first' // 'obj2' inherits 'c' from 'SubObjMaker.prototype', 'b' from 'ObjMaker.prototype', and 'a' from 'ObjMaker'
En résumé, le mot-clé 'new' en JavaScript facilite non seulement la création d'objets, mais permet également un mécanisme d'héritage flexible qui simule des classes basées sur les classes. programmation.
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!