이 글은 Node.js의 순환 의존성 문제를 해결하는 두 가지 방법을 소개합니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.
이 글의 초점은 순환 종속성 문제를 해결하는 방법을 설명하는 것입니다. 이 문제가 어떻게 발생하는지에 관심이 있다면 Google에서 직접 검색해 볼 수 있습니다.
이 문제를 재현하는 방법
// 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 }
다음 코드 실행
➜ 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는 함수가 아닙니다
그러면 sayA는 a 실제로는 정의되지 않았습니다
sayA is not a function
那么sayA是个什么呢,实际上它是 undefined
遇到这种问题时,你最好能意识到可能是循环依赖的问题
이런 종류의 문제가 발생하면 순환 종속성 문제일 수 있다는 점을 인식하는 것이 좋습니다
, 그렇지 않으면 문제를 찾는 데 드는 노력이 절반으로 줄어들 수 있습니다. 순환 종속성이 있는 파일을 찾는 방법
위의 샘플 코드는 매우 간단합니다. 파일이 2개이므로 순환 종속성을 쉽게 찾을 수 있습니다. . 파일이 12개 이상일 경우 순환 종속 파일을 수동으로 찾는 것은 매우 번거로운 작업입니다. 다음은 파일 간의 종속성을 시각적으로 볼 수 있는 도구 madge를 권장합니다. 아래 그림 1에 주목하세요. cli.js를 시작점으로 하면 모든 화살표가 오른쪽으로 확장됩니다. 이는 순환 종속성이 없음을 나타냅니다. 왼쪽으로 역류를 가리키는 화살표가 있으면 순환 의존성 지점일 수 있습니다. 그림 2에는 왼쪽 화살표가 나타나 순환 종속성이 있음을 나타내며 여기서 순환을 깨야 함을 나타냅니다.
#🎜 🎜#【그림 2】
순환 종속성을 해결하는 방법
옵션 1: 자신의 모듈을 먼저 내보내기#🎜🎜 ## 🎜🎜#module.exports를 파일의 선두에 두고, 자신의 모듈을 먼저 내보낸 다음 다른 모듈을 가져옵니다
// 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') }옵션 2: 간접 호출
# 🎜🎜# 이벤트 메시지 전달 기능을 도입하여 여러 모듈이 간접적으로 메시지를 전달할 수 있고, 여러 모듈이 메시지를 보내 서로 호출할 수도 있습니다.
// 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()
Summary
#순환 종속성이 발생하면 코드 구조에 문제가 있는 경우가 많습니다. 순환 의존성과 같은 문제를 피하기 위해 우리는 솔선해야 하지만, 그러한 문제에 직면하고 피할 수 없을 때, 문제가 순환 의존성으로 인해 발생한다는 사실을 깨닫고 해결책을 찾아야 합니다.
마지막으로, node a.js를 실행할 때 다음 코드는 무엇을 출력할까요? 왜 이런 일이 발생합니까? #🎜🎜 #// 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 }rrree
위 내용은 Node.js의 순환 종속성 문제를 해결하는 두 가지 방법 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!