


js encapsule la fonction _new et comment implémenter le nouveau mot-clé (avec test de code)
Le contenu de cet article concerne l'encapsulation js de la fonction _new et la méthode d'implémentation d'un nouveau mot-clé (avec test de code). Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. . a aidé.
1. Introduction
Comme nous le savons tous : que dois-je faire si je n’ai pas d’objet ? Alors achetez-en un nouveau !
Donc, en JS, lorsque nous renouvelons un objet, que fait le nouveau mot-clé à l'intérieur ?
Analysons maintenant le principe de fonctionnement interne du nouveau mot-clé en JS natif.
2. Original neuf
Tout d'abord, jetons un coup d'œil à un nouvel objet :
//创建Person构造函数,参数为name,age function Person(name,age){ this.name = name; this.age = age; } //实例化对象小明 xm = new Person('xiaoming',18); //打印实例化出来的对象小明 console.log(xm);
Résultats de l'impression :
Comme vous pouvez le voir dans les résultats de l'impression :
Lors de l'instanciation d'un objet avec le nouveau Mot-clé , a d'abord créé un objet vide xm, et cet objet vide contient deux attributs name et age, qui correspondent respectivement aux deux attributs du constructeur. Deuxièmement, nous pouvons également savoir que l'objet instancié xm est hérité de Person.prototype, donc. nous pouvons maintenant résumer ce que fait le mot-clé new en interne lors de l'instanciation d'un objet. En fait, le mot-clé new fait les trois choses suivantes en interne (le constructeur connu est Func) :
Créer un vide. object et faites en sorte que l'objet vide hérite de Func.prototype;
Exécutez le constructeur et pointez-le vers le nouvel objet que vous venez de créer
Renvoyer un ; new object;
3. Encapsulation_new function
Quand on connaît le principe interne du new mot-clé Ensuite, on peut encapsuler une _new function donc qu'il peut être utilisé pour la même fonction que le mot-clé new. La fonction
_new doit transmettre les paramètres suivants :
Le premier paramètre : le nom de la fonction constructeur Func
Le deuxième paramètre et les paramètres suivants : les paramètres du constructeur
function _new(){ //1.拿到传入的参数中的第一个参数,即构造函数名Func var Func = [].shift.call(arguments); //2.创建一个空对象obj,并让其继承Func.prototype var obj = Object.create(Func.prototype); //3.执行构造函数,并将this指向创建的空对象obj Func.apply(obj,arguments) //4.返回创建的对象obj return obj }
4. Testons la fonction _new
Après l'encapsulation, testons la fonction _new encapsulée et voyons si elle implémente la même chose. fonctionner comme le nouveau mot-clé natif.
//创建Person构造函数,参数为name,age function Person(name,age){ this.name = name; this.age = age; } function _new(){ //1.拿到传入的参数中的第一个参数,即构造函数名Func var Func = [].shift.call(arguments); //2.创建一个空对象obj,并让其继承Func.prototype var obj = Object.create(Func.prototype); //3.执行构造函数,并将this指向创建的空对象obj Func.apply(obj,arguments) //4.返回创建的对象obj return obj } xm = _new(Person,'xiaoming',18); console.log(xm);
Résultats des tests :
À partir des résultats des tests, nous pouvons voir que la fonction _new La fonction est exactement la même que le mot-clé new.
Recommandations associées :
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Des questions et des solutions fréquemment posées pour l'impression de billets thermiques frontaux pour le développement frontal, l'impression de billets est une exigence commune. Cependant, de nombreux développeurs mettent en œuvre ...

Il n'y a pas de salaire absolu pour les développeurs Python et JavaScript, selon les compétences et les besoins de l'industrie. 1. Python peut être davantage payé en science des données et en apprentissage automatique. 2. JavaScript a une grande demande dans le développement frontal et complet, et son salaire est également considérable. 3. Les facteurs d'influence comprennent l'expérience, la localisation géographique, la taille de l'entreprise et les compétences spécifiques.

Comment fusionner les éléments du tableau avec le même ID dans un seul objet en JavaScript? Lors du traitement des données, nous rencontrons souvent la nécessité d'avoir le même ID ...

JavaScript est la pierre angulaire du développement Web moderne, et ses principales fonctions incluent la programmation axée sur les événements, la génération de contenu dynamique et la programmation asynchrone. 1) La programmation axée sur les événements permet aux pages Web de changer dynamiquement en fonction des opérations utilisateur. 2) La génération de contenu dynamique permet d'ajuster le contenu de la page en fonction des conditions. 3) La programmation asynchrone garantit que l'interface utilisateur n'est pas bloquée. JavaScript est largement utilisé dans l'interaction Web, les applications à une page et le développement côté serveur, améliorant considérablement la flexibilité de l'expérience utilisateur et du développement multiplateforme.

Discussion approfondie des causes profondes de la différence de sortie Console.log. Cet article analysera les différences dans les résultats de sortie de la fonction Console.log dans un morceau de code et expliquera les raisons derrière. � ...

La discussion sur la réalisation des effets de défilement de parallaxe et d'animation des éléments dans cet article explorera comment réaliser le site officiel de Shiseido (https://www.shiseido.co.jp/sb/wonderland/) ...

Une fois que vous avez maîtrisé le didacticiel TypeScript de niveau d'entrée, vous devriez être en mesure d'écrire votre propre code dans un IDE qui prend en charge TypeScript et de le compiler en JavaScript. Ce tutoriel plongera dans divers types de données dans TypeScript. JavaScript a sept types de données: null, non défini, booléen, numéro, chaîne, symbole (introduit par ES6) et objet. TypeScript définit plus de types sur cette base, et ce tutoriel les couvrira tous en détail. Type de données nuls Comme javascript, null en typeScript

JavaScript peut être exécuté dans PowerPoint et peut être implémenté en appelant des fichiers JavaScript externes ou en intégrant des fichiers HTML via VBA. 1. Pour utiliser VBA pour appeler les fichiers JavaScript, vous devez activer les macros et avoir des connaissances en programmation VBA. 2. ENCHED des fichiers HTML contenant JavaScript, qui sont simples et faciles à utiliser mais sont soumis à des restrictions de sécurité. Les avantages incluent les fonctions étendues et la flexibilité, tandis que les inconvénients impliquent la sécurité, la compatibilité et la complexité. En pratique, l'attention doit être accordée à la sécurité, à la compatibilité, aux performances et à l'expérience utilisateur.
