Modules ES vs CommonJS: une comparaison détaillée
Les modules ES (ESM) et CommonJS sont deux systèmes de modules de JavaScript. Les principales différences sont la syntaxe, le mécanisme de chargement, le calendrier d'exécution, la prise en charge de l'environnement et l'interopérabilité. 1. Syntaxe, ESM utilise l'importation / exportation vers les déclarations statiques et CommonJS utilise require () / module.exports pour attribuer dynamiquement des valeurs. 2. En termes de mécanisme de chargement, l'ESM prend en charge l'analyse statique et la partage d'arbres. CommonJS est chargé dynamiquement au moment de l'exécution, avec une forte flexibilité mais pas propice à l'optimisation. 3. Au moment de l'exécution, ESM peut obtenir la dernière valeur par liaison en temps réel; La sortie du module de cache CommonJS peut renvoyer la partie de l'objet d'initialisation. 4. En termes de support environnemental, le navigateur prend en charge nativement l'ESM. Node.js prend en charge ESM via .mjs ou "type": "module" de V12, et CommonJS est utilisé par défaut. 5. En termes d'interopérabilité, ESM peut importer directement les modules CommonJS (notez l'importation par défaut), mais CommonJS ne peut pas nécessiter directement des modules ESM et une importation dynamique () est requise. 6. Dans la chaîne d'outils et l'écosystème, WebPack, Vite, etc. sont mieux pris en charge par ESM. Il est recommandé que les nouveaux projets utilisent l'ESM. Les anciens projets peuvent être progressivement migrés. Lors de la libération de packages NPM, ils doivent fournir des versions ESM et CommonJS et contrôler avec précision l'entrée via le champ d'exportations. La conclusion finale est que les nouveaux projets devraient prioriser l'ESM pour de meilleures performances et compatibilité.
Les modules ES (ESM) et CommonJS sont deux systèmes de modules grand public en JavaScript, qui dominent respectivement les navigateurs modernes et les premiers environnements Node.js. Avec le développement de JavaScript, les deux ont des différences évidentes de syntaxe, de mécanisme de chargement, de compatibilité, etc.

1. Différences de grammaire: comparaison intuitive des méthodes d'écriture
Il s'agit de la différence la plus évidente, ce qui affecte directement le style de code.
CommonJS (Node.js Early Standard)

// export module.exports = {foo}; // ou export.foo = foo; // importe const {foo} = require ('./ foo');
Modules ES (norme moderne)
// Exportation d'exportation const foo = 'bar'; Exporter par défaut foo; // importe l'importation {foo} depuis './foo.js'; Importer MyDefault à partir de './foo.js';
- ESM utilise le mot-clé d'
import
/export
, qui est une syntaxe statique au niveau du langage. - CommonJS utilise la fonction
require()
et l'objetmodule.exports
, qui appartient à la charge dynamique au moment de l'exécution.
✅ Conseils: ESM nécessite des extensions de fichiers plus strictes (telles que
.js
), tandis que les communjs peuvent être omis dans le nœud.
2. Mécanisme de chargement: statique vs dynamique
Il s'agit de la différence de base, affectant les performances et les capacités d'optimisation des outils.
caractéristiques | Modules ES | CommonJS |
---|---|---|
Méthode de chargement | Analyse statique (temps de compilation) | Chargement dynamique (runtime) |
Si la part des arbres est soutenue | ✅ Oui | ❌ Non |
Est-il possible d'importer dynamiquement | ❌ import de base ne peut pas fonctionner (mais il y a import() ) | ✅Require require() peut être appelé n'importe où |
- La nature statique de l'ESM signifie que les outils d'emballage (tels que WebPack et Rollup) peuvent analyser les dépendances au moment de la construction, éliminer le code inutilisé (partage d'arbres) et réduire considérablement la taille de l'emballage.
- La nature dynamique de CommonJS vous fait
require
des modules dans des conditionsif
, qui sont plus flexibles, mais rendent également une analyse statique difficile.
Exemple:
if (condition) { const mod = require («quelque module»); // ✅ CommonJS permet} // La logique similaire dans ESM nécessite une importation dynamique: if (condition) { const mod = attendre l'importation («quelque module»); // ✅ Import dynamique ESM}
3. Tiration d'exécution et traitement de la dépendance circulaire
L'ordre d'exécution des modules est différent de la méthode de traitement des références circulaires.
CommonJS : Le module est exécuté sur la première
require
et cache le résultat (une copie superficielle demodule.exports
). Lorsqu'une dépendance circulaire est rencontrée, un objet partiellement initialisé peut être renvoyé.// A.JS console.log («un départ»); const b = require ('./ b'); export.done = true; // b.js Console.log («B Start»); const a = require ('./ a'); // référence circulaire
La sortie peut être:
un départ B Début
À l'heure actuelle,
a
n'a pas encore été exécuté et ce queb
obtient l'état intermédiaire dea
.ESM : Tous les modules sont des références singleton et les dépendances circulaires sont gérées via le mécanisme "lien". Même s'il est référencé dans une boucle, la valeur finale de
export
peut être correctement liée.// A.MJS import {b} de './b.mjs'; exportation const a = 'a'; // b.mjs import {a} de './a.mjs'; exportation const b = 'b';
Bien qu'il y ait une boucle, car ESM utilise des "liaisons en direct", vous pouvez obtenir la dernière valeur pendant l'accès.
? Point clé: ESM Export est une "référence en lecture seule" et non une copie de valeur. Modifier les variables du module d'origine et l'importateur peut également voir les modifications.
4. Statut de support du navigateur et Node.js
environnement | Prise en charge de l'ESM | Soutenir CommonJS |
---|---|---|
Navigateur | ✅ Prise en charge native (nécessite <script type="module"> ) | ❌ Pas pris en charge (sauf si emballé) |
Node.js (V12) | ✅ support ( "type": "module" dans .mjs fichiers ou package.json ) | ✅ Prise en charge par défaut (fichier .js ) |
- Utilisation mixte dans Node.js:
-
.cjs
Extension Forces CommonJS. -
.mjs
Forces ESM. - Le comportement du fichier
.js
est déterminé par le champ"type"
depackage.json
.
-
{ "type": "module" }
⚠️ Vous ne pouvez pas
require()
un fichier.mjs
Lors de l'importation de systèmes de modules, une erreur sera signalée.
5. Interopérabilité: comment l'utiliser dans un mélange?
L'interopérabilité est souvent requise dans les projets de migration ou hybrides.
Importer le module CommonJS (Node.js) dans ESM
import _ de «lodash»; // ✅ Oui, mais notez que l'importation par défaut import {par défaut comme _} de 'lodash'; // plus explicite
Importation de modules ESM dans CommonJS❌ Vous ne pouvez pas
require()
le module ESM.Alternatives:
- Utiliser Dynamic
import()
(retour à Promise):Fonction asynchrone charge () { const mod = attendre import ('./ esm-module.mjs'); }
- Ou transformation unifiée via des outils de construction.
- Utiliser Dynamic
6. Répartition de l'outil et impact écologique
Outil d'emballage (WebPack / Vite / Rollup)
- Plus de préférence pour l'ESM est propice à l'optimisation.
- VITE est basé sur l'environnement de développement ESM par défaut (en utilisant la prise en charge native du navigateur).
Version du package NPM
- Il est recommandé de fournir des versions ESM et CommonJS.
- Utilisez
exports
pour contrôler précisément:{ "Main": "./index.cjs", "module": "./index.mjs", "Exportations": { "import": "./index.mjs", "Besoin": "./index.cjs" } }
Résumé: lequel dois-je utiliser?
Scène recommander Nouveau projet (en particulier frontal) ✅ modules ES Node.js Backend Old Project ? Vous pouvez continuer à utiliser CommonJS et à migrer progressivement Besoin de tremblements d'arbres ou de support natif du navigateur ✅ ESM requis Chargement de l'état dynamique et non emballé ✅ CommonJS est plus flexible (mais peut être remplacé par import()
)Publier le package NPM ✅ prend en charge ESM et CommonJS en même temps
Désormais, Node.js et les navigateurs ont entièrement pris en charge ESM, qui est l'avenir des systèmes de modules JavaScript. Bien que CommonJS soit encore répandu, les nouveaux projets recommandent de hiérarchiser les modules ES pour de meilleures performances, la maintenabilité et la compatibilité avec les chaînes d'outils modernes.
Fondamentalement, tout est, pas compliqué, mais il est facile d'ignorer les détails.
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

Undress AI Tool
Images de déshabillage gratuites

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.

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)

La portée de JavaScript détermine la portée d'accessibilité des variables, qui sont divisées en étendue globale, fonction et au niveau du bloc; Le contexte détermine la direction de cela et dépend de la méthode d'appel de fonction. 1. Les étendues incluent la portée globale (accessible n'importe où), la portée de la fonction (valide uniquement dans la fonction) et la portée au niveau du bloc (LET et const sont valides dans {}). 2. Le contexte d'exécution contient l'objet variable, la chaîne de portée et les valeurs de cela. Cela pointe vers global ou non défini dans la fonction ordinaire, l'appel de méthode pointe vers l'objet d'appel, le constructeur pointe vers le nouvel objet, et peut également être explicitement spécifié par appel / application / liaison. 3. La fermeture fait référence aux fonctions accédant et en se souvenant des variables de portée externes. Ils sont souvent utilisés pour l'encapsulation et le cache, mais peuvent provoquer

CompositionAPI dans Vue3 convient plus à la logique complexe et à la dérivation de type, et OptionsAPI convient aux scénarios et débutants simples; 1. OptionsAPI organise le code en fonction d'options telles que les données et les méthodes, et a une structure claire mais les composants complexes sont fragmentés; 2. CompositionAPI utilise la configuration pour concentrer la logique liée, ce qui est propice à la maintenance et à la réutilisation; 3. CompositionAPI réalise la réutilisation logique sans conflit et paramétrisable par le biais de fonctions composables, ce qui est mieux que le mixin; 4. CompositionAPI a une meilleure prise en charge de la dérivation de type dactylographiée et de type plus précise; 5. Il n'y a pas de différence significative dans le volume de performances et d'emballage des deux; 6.

Il existe une différence essentielle entre les travailleurs Web de JavaScript et Javathreads dans un traitement simultané. 1. JavaScript adopte un modèle unique. WebWorkers est un fil indépendant fourni par le navigateur. Il convient pour effectuer des tâches longues qui ne bloquent pas l'interface utilisateur, mais ne peuvent pas utiliser le DOM; 2. Java prend en charge le multithreading réel à partir du niveau de la langue, créé via la classe de threads, adapté à un traitement simultanée complexe et côté serveur; 3. Les travailleurs Web utilisent PostMessage () pour communiquer avec le fil principal, qui est hautement sécurisé et isolé; Les threads Java peuvent partager la mémoire, de sorte que les problèmes de synchronisation doivent être prêts à prêter attention; 4. Les travailleurs Web sont plus adaptés à l'informatique parallèle frontale, comme le traitement d'image, et

La coulée de type est le comportement de la conversion automatique d'un type de valeur en un autre type en JavaScript. Les scénarios courants incluent: 1. Lorsque vous utilisez des opérateurs, si un côté est une chaîne, l'autre côté sera également converti en une chaîne, comme '5' 5. Le résultat est "55"; 2. Dans le contexte booléen, les valeurs non cooliennes seront implicitement converties en types booléens, tels que des chaînes vides, 0, nuls, non définies, etc., qui sont considérées comme fausses; 3. Null participe aux opérations numériques et sera convertie en 0, et non défini sera converti en NAN; 4. Les problèmes causés par la conversion implicite peuvent être évitées grâce à des fonctions de conversion explicites telles que Number (), String () et Boolean (). La maîtrise de ces règles aide

Les dates de format dans JavaScript peuvent être implémentées via des méthodes natives ou des bibliothèques tierces. 1. Utilisez des coutures d'objets à date native: Obtenez la partie de date via Gettillyar, Getmonth, GetDate et d'autres méthodes, et les épisser manuellement dans des formats Yyyy-MM et d'autres, qui conviennent aux besoins légers et ne reposent pas sur des bibliothèques tierces; 2. Utilisez la méthode TolocaleDateString: vous pouvez sortir tel que le format mm / dd / yyyy en fonction des habitudes locales, en charge multilingue, mais le format peut être incohérent en raison de différents environnements; 3. Utilisez des bibliothèques tierces telles que Day.js ou Date-FNS: Fournit une syntaxe concise et des fonctions riches, adaptées aux opérations fréquentes ou lorsque l'extensibilité est requise, comme DayJS ()

Initialiser le projet et créer package.json; 2. Créez un script d'entrée index.js avec shebang; 3. Registre des commandes via des champs bin dans package.json; 4. Utilisez des Yargs et d'autres bibliothèques pour analyser les paramètres de ligne de commande; 5. Utilisez le test local NPMLink; 6. Ajouter l'aide, la version et les options pour améliorer l'expérience; 7. Publier éventuellement via NPMPublish; 8. Affectuer éventuellement l'achèvement automatique avec Yargs; Enfin, créez des outils CLI pratiques grâce à une structure raisonnable et à une conception de l'expérience utilisateur, effectuer des tâches d'automatisation ou distribuer des widgets et se terminer par des phrases complètes.

Utilisez Document.CreateElement () pour créer de nouveaux éléments; 2. Personnaliser les éléments via TextContent, ClassList, SetAttribute et d'autres méthodes; 3. Utilisez des méthodes APPEDCHILD () ou plus flexibles APPEND () pour ajouter des éléments au DOM; 4. Utiliser éventuellement INSERTBEFORE (), avant () et d'autres méthodes pour contrôler la position d'insertion; Le processus complet consiste à créer → Personnaliser → Ajouter, et vous pouvez mettre à jour dynamiquement le contenu de la page.

Les types de conditions avancées de TypeScript implémentent le jugement logique entre les types via TextendU? X: Y Syntaxe. Ses capacités de base se reflètent dans les types de conditions distribuées, l'inférence de type inférieure et la construction d'outils de type complexe. 1. Le type conditionnel est distribué dans les paramètres de type nu et peut automatiquement diviser le type de joint, tel que pour obtenir la chaîne [] | nombre []. 2. Utiliser la distribution pour construire des outils de filtrage et d'extraction: exclut exclut les types via TextendU? Never: T, extraire extrait les points communs via TextendU? T: jamais, et des filtres non nuls nuls / non définis. 3
