Explication détaillée du module module Node
Lors du développement d'applications Web complexes, il est généralement nécessaire de diviser chaque fonction, de l'encapsuler dans différents fichiers et de référencer le fichier si nécessaire, c'est-à-dire une gestion modulaire du code. Presque tous les langages de programmation ont leurs propres méthodes d'organisation des modules, telles que les packages en Java et les assemblys en C#, et Node adopte la spécification du module CommonJS.
Spécification du module
CommonJS vise à standardiser JS qui s'exécute en dehors du navigateur et a résolu un grand nombre de problèmes JS ( tels que les conflits de noms mondiaux). Dans l'implémentation Node de CommonJS, chaque module sera encapsulé dans un fichier JS distinct, c'est-à-dire qu'un fichier est un module et le chemin du fichier est le nom du module. Lors de l'écriture de chaque module, les trois variables prédéfinies suivantes sont disponibles :
require()
Cette fonction est utilisée dans Pour charger et utiliser d'autres modules dans le module actuel, transmettez un nom de module et renvoyez un objet d'exportation de module. Le nom du module peut utiliser un chemin relatif (commençant par ./) ou un chemin absolu (commençant par / ou une lettre de lecteur telle que C :). De plus, l'extension .js dans le nom du module peut être omise. À ce stade, Node recherchera un dossier du même nom. S'il est introuvable, il recherchera un fichier js du même nom. Vous pouvez également utiliser cette fonction pour charger et utiliser un fichier JSON, mais l'extension .json ne peut pas être omise.
exports
Cet objet est l'objet d'exportation du module actuel et est utilisé pour exporter les méthodes et propriétés publiques du module. Il est par défaut un objet vide. {}. Lorsque d'autres modules utilisent le module actuel via la fonction require(), ils obtiennent l'objet exports du module actuel. Une méthode publique est exportée dans le code suivant :
exports.hello = function() { console.log("Hello World!"); };
module
Cet objet permet de fournir les métadonnées du module actuel et d'autres informations associées, mais la plus utile est d'utiliser son attribut exports pour remplacer l'objet d'exportation du module actuel. Par exemple, l'objet d'exportation du module est un objet normal par défaut. Vous pouvez utiliser la méthode suivante pour le transformer en fonction :
module.exports = function() { console.log("Hello World!"); };
Remarque : lors de l'utilisation du méthode ci-dessus, l'objet exports Toutes les modifications seront ignorées !
Initialisation du module
Le code JS dans un module n'est exécuté qu'une seule fois lors de la première utilisation du module, et est initialisé lors exécution L'objet exporté du module. Ultérieurement, l'objet d'exportation mis en cache est réutilisé.
Définir un module dans test.js
//定义私有变量 var name = ""; function setName(n) { name = n; } function logName() { console.log(name); } //导出公有方法 exports.setName = setName; exports.logName = logName;
Charger le module de test dans main
//加载test模块 var test1 = require("./test.js"), test2 = require("./test.js"); //使用test1 test1.setName("Neo"); //使用test2 test2.logName(); //Neo
On peut voir que peu importe le nombre d'appels de require(), le même module n'est chargé qu'une seule fois et la même instance est obtenue en référençant plusieurs fois.
Module principal
Le module transmis à Node via les paramètres de ligne de commande pour démarrer le programme est appelé module principal. Le module principal est responsable. pour planifier et composer l'ensemble de l'application. D'autres modules du programme fonctionnent ensemble. Par exemple, lors du démarrage du programme via la ligne de commande suivante, main.js est le module principal :
$ node main.js
Module binaire
En plus d'utiliser JS pour écrire des modules, Node prend également en charge l'utilisation de C/C++ pour écrire des modules binaires. Les modules binaires compilés peuvent être utilisés de la même manière que les modules JS, sauf que l'extension de fichier est. .nœud. Bien que les modules binaires puissent utiliser toutes les fonctions fournies par le système d'exploitation, ils sont difficiles à utiliser sur toutes les plateformes.
Recommandations associées :
Explication détaillée de la syntaxe du module dans JavaScript ES6
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

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

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)

Sujets chauds





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 de la fonction mode en C++ En statistiques, le mode fait référence à la valeur qui apparaît le plus fréquemment dans un ensemble de données. En langage C++, nous pouvons trouver le mode dans n’importe quel ensemble de données en écrivant une fonction de mode. La fonction mode peut être implémentée de nombreuses manières différentes, deux des méthodes couramment utilisées seront présentées en détail ci-dessous. La première méthode consiste à utiliser une table de hachage pour compter le nombre d'occurrences de chaque nombre. Tout d’abord, nous devons définir une table de hachage avec chaque nombre comme clé et le nombre d’occurrences comme valeur. Ensuite, pour un ensemble de données donné, nous exécutons

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 de la fonction reste en C++ En C++, l'opérateur reste (%) est utilisé pour calculer le reste de la division de deux nombres. Il s'agit d'un opérateur binaire dont les opérandes peuvent être n'importe quel type entier (y compris char, short, int, long, etc.) ou un type nombre à virgule flottante (tel que float, double). L'opérateur reste renvoie un résultat du même signe que le dividende. Par exemple, pour l'opération de reste des entiers, nous pouvons utiliser le code suivant pour implémenter : inta=10;intb=3;

Explication détaillée de l'utilisation de la fonction Vue.nextTick et de son application dans les mises à jour asynchrones. Dans le développement de Vue, nous rencontrons souvent des situations où les données doivent être mises à jour de manière asynchrone. Par exemple, les données doivent être mises à jour immédiatement après la modification du DOM ou des opérations associées. à effectuer immédiatement après la mise à jour des données. La fonction .nextTick fournie par Vue a émergé pour résoudre ce type de problème. Cet article présentera en détail l'utilisation de la fonction Vue.nextTick et la combinera avec des exemples de code pour illustrer son application dans les mises à jour asynchrones. 1. Vue.nex

Explication détaillée et guide d'installation pour les nœuds de pignon Cet article introduira l'écosystème de pignon en détail - nœuds PI, un rôle clé dans l'écosystème de pignon et fournir des étapes complètes pour l'installation et la configuration. Après le lancement du réseau de test de la blockchain pèse, les nœuds PI sont devenus une partie importante de nombreux pionniers participant activement aux tests, se préparant à la prochaine version du réseau principal. Si vous ne connaissez pas encore Pinetwork, veuillez vous référer à ce qu'est Picoin? Quel est le prix de l'inscription? PI Utilisation, exploitation minière et sécurité. Qu'est-ce que Pinetwork? Le projet Pinetwork a commencé en 2019 et possède sa pièce exclusive de crypto-monnaie PI. Le projet vise à en créer un que tout le monde peut participer

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() 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
