Maison >interface Web >js tutoriel >Comment fonctionne l'opérateur « nouveau » en JavaScript et comment crée-t-il des objets avec leurs chaînes de prototypes ?
Comment fonctionne le nouvel opérateur en JavaScript ?
Le nouvel opérateur joue un rôle central dans le système de programmation orienté objet de JavaScript. Il est essentiel de comprendre ses fonctionnalités pour créer et gérer efficacement des objets.
Plongée dans la mise en œuvre du nouvel opérateur
<code class="javascript">new dataObj(args);</code>
Cet extrait de code utilise le [[ Construct]] méthode pour effectuer une série d'actions spécifiques :
Une implémentation alternative pour plus de clarté
Pour améliorer la compréhension, voici une représentation alternative de ce que réalise le nouvel opérateur :
<code class="javascript">function NEW(f) { var obj, ret, proto; // Check if `f.prototype` is an object, not a primitive proto = Object(f.prototype) === f.prototype ? f.prototype : Object.prototype; // Create an object that inherits from `proto` obj = Object.create(proto); // Apply the function setting `obj` as the `this` value ret = f.apply(obj, Array.prototype.slice.call(arguments, 1)); if (Object(ret) === ret) { // the result is an object? return ret; } return obj; } // Example usage: function Foo (arg) { this.prop = arg; } Foo.prototype.inherited = 'baz'; var obj = NEW(Foo, 'bar'); obj.prop; // 'bar' obj.inherited; // 'baz' obj instanceof Foo // true</code>
Dans cet exemple :
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!