사용자마다 다른 피드백을 제공하기 위해 이벤트 핸들러 모듈을 도입합니다.
이 모듈의 이름은 requestHandlers입니다. 먼저 start() 및 upload()라는 두 가지 자리 표시자 함수를 추가합니다.
requestHandlers.js 코드는 다음과 같습니다.
실제 애플리케이션에서는 요청 핸들러의 수가 계속해서 증가할 것이며, 새로운 URL이나 요청 핸들러가 있을 때마다 경로에서 요청을 완료할 필요는 없습니다.
핸들러에 매핑하고 계속해서 던지는 것입니다.
또한 라우팅에서 if request == x 그런 다음 핸들러 y를 호출하는 경우가 많아 코드가 지저분하고 비전문적으로 보일 수 있기를 원하지 않습니다.
여기서는 연관 배열의 개념을 사용하여 이 요구 사항을 처리합니다. 객체를 통해 일련의 요청 핸들러를 전달하고 이 객체를 느슨하게 결합된 방식으로 Route() 함수에 삽입해야 합니다.
먼저 이 개체를 기본 파일 index.js에 소개합니다.
예를 들어, /show 매핑을 추가하려면 handler["/show"] requestHandlers.show만 추가하면 됩니다.
하하, 이렇게 하면 코드가 더 간결해지고 질서정연해지나요? !
다음으로 핸들 개체를 서버에 전달하고 다음과 같이 server.js를 수정합니다.
route.js 파일에서 Route() 함수를 이에 맞게 수정합니다.
핸들 객체를 서버에 매개변수로 전달하고, 이를 라우터가 수신합니다. 마지막으로 라우터는 현재 경로에 해당하는 요청 핸들러가 존재하는지 확인하고 해당 함수를 호출합니다.
연관 배열에서 요소를 가져오는 것과 동일한 방식으로 전달된 개체에서 요청 처리 기능을 가져올 수 있으므로 다음과 같은 느낌이 드는 간단하고 부드러운 표현인 Handle[경로명]();을 갖게 됩니다. 앞에서 언급한 내용: "이 길을 안내해 주세요."
이러한 방식으로 다양한 요청을 다르게 처리할 수 있습니다.
다음 섹션에서는 서버가 실제 피드백 작업을 수행할 수 있도록 코드를 추가로 수정하겠습니다.