Maison > Article > interface Web > Une introduction à deux méthodes pour résoudre les problèmes de dépendance circulaire dans Node.js
Ce que cet article vous apporte est une introduction à deux méthodes de résolution des problèmes de dépendance circulaire dans Node.js. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.
L'objectif de cet article est d'expliquer comment résoudre le problème des dépendances circulaires. Si vous souhaitez savoir comment ce problème survient, vous pouvez le rechercher vous-même sur Google.
Comment reproduire ce problème
// a.js const {sayB} = require('./b.js') sayB() function sayA () { console.log('say A') } module.exports = { sayA }
// b.js const {sayA} = require('./a.js') sayA() function sayB () { console.log('say B') } module.exports = { sayB }
Exécutez le code suivant
➜ test git:(master) ✗ node a.js /Users/dd/wj-gitlab/tools/test/b.js:3 sayA() ^ TypeError: sayA is not a function at Object.<anonymous> (/Users/dd/wj-gitlab/tools/test/b.js:3:1) at Module._compile (module.js:635:30) at Object.Module._extensions..js (module.js:646:10) at Module.load (module.js:554:32) at tryModuleLoad (module.js:497:12) at Function.Module._load (module.js:489:3) at Module.require (module.js:579:17) at require (internal/module.js:11:18) at Object.<anonymous> (/Users/dd/wj-gitlab/tools/test/a.js:1:78) at Module._compile (module.js:635:30)</anonymous></anonymous>
sayA is not a function
Alors, qu'est-ce que sayA, en fait, c'est le casundefined
遇到这种问题时,你最好能意识到可能是循环依赖的问题
, sinon vous risquez d'obtenir le double du résultat avec la moitié de l'effort nécessaire pour trouver le problème.
Comment trouver des fichiers de dépendances circulaires
L'exemple de code ci-dessus est très simple, avec 2 fichiers, il est facile de trouver des dépendances circulaires. S'il y a plus d'une douzaine de fichiers, il est très difficile de rechercher manuellement les fichiers dépendants de manière circulaire.
Ce qui suit est un outil madge, qui peut visualiser visuellement les dépendances entre les fichiers.
Faites attention à la figure 1 ci-dessous. En prenant cli.js comme point de départ, toutes les flèches se développent vers la droite, ce qui montre qu'il n'y a pas de dépendances circulaires. S'il y a une flèche pointant à contre-courant vers la gauche, il peut s'agir d'un point de dépendance circulaire.
Dans la figure 2, la flèche gauche apparaît, indiquant qu'une dépendance circulaire s'est produite, indiquant que le cycle doit être rompu ici.
[Photo 1]
[Photo 2]
Comment résoudre les dépendances circulaires
Option 1 : Exportez d'abord votre propre module
Mettez module.exports en tête du fichier, exportez d'abord votre propre module , puis Importer d'autres modules
// a.js module.exports = { sayA } const {sayB} = require('./b.js') sayB() function sayA () { console.log('say A') }
// b.js module.exports = { sayB } const {sayA} = require('./a.js') console.log(typeof sayA) sayA() function sayB () { console.log('say A') }
Solution 2 : Appeler indirectement
en introduisant un passage de message d'événement, afin que plusieurs modules puissent transmettre des messages indirectement . Plusieurs modules peuvent également s'appeler en envoyant des messages.
// a.js require('./b.js') const bus = require('./bus.js') bus.on('sayA', sayA) setTimeout(() => { bus.emit('sayB') }, 0) function sayA () { console.log('say A') } module.exports = { sayA }
// b.js const bus = require('./bus.js') bus.on('sayB', sayB) setTimeout(() => { bus.emit('sayA') }, 0) function sayB () { console.log('say B') } module.exports = { sayB }
// bus.js const EventEmitter = require('events') class MyEmitter extends EventEmitter {} module.exports = new MyEmitter()
Résumé
Lorsque des dépendances circulaires se produisent, il y a souvent un problème avec la structure du code. Vous devez prendre l'initiative d'éviter des problèmes tels que les dépendances circulaires, mais lorsque vous rencontrez de tels problèmes et que vous ne pouvez pas les éviter, vous devez également réaliser que les problèmes sont causés par des dépendances circulaires et trouver des solutions.
Enfin, j'ai une question intéressante. Que produira le code suivant lors de l'exécution de node a.js ? Pourquoi cela se produit-il ?
// a.js var moduleB = require('./b.js') setInterval(() => { console.log('setInterval A') }, 500) setTimeout(() => { console.log('setTimeout moduleA') moduleB.sayB() }, 2000) function sayA () { console.log('say A') } module.exports = { sayA }
// b.js var moduleA = require('./a.js') setInterval(() => { console.log('setInterval B') }, 500) setTimeout(() => { console.log('setTimeout moduleB') moduleA.sayA() }, 2000) function sayB () { console.log('say B') } module.exports = { sayB }
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!