>웹 프론트엔드 >JS 튜토리얼 >Node.js의 순환 종속성 문제를 해결하는 두 가지 방법 소개

Node.js의 순환 종속성 문제를 해결하는 두 가지 방법 소개

不言
不言앞으로
2018-10-26 15:54:183822검색

이 글은 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에는 왼쪽 화살표가 나타나 순환 종속성이 있음을 나타내며 여기서 순환을 깨야 함을 나타냅니다.

Node.js의 순환 종속성 문제를 해결하는 두 가지 방법 소개

【사진 1】

Node.js의 순환 종속성 문제를 해결하는 두 가지 방법 소개

#🎜 🎜#【그림 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 segmentfault.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제