>웹 프론트엔드 >JS 튜토리얼 >nodejs 서버를 쉽게 생성하세요 (5): event handler_node.js

nodejs 서버를 쉽게 생성하세요 (5): event handler_node.js

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB원래의
2016-05-16 16:25:491096검색

사용자마다 다른 피드백을 제공하기 위해 이벤트 핸들러 모듈을 도입합니다.

이 모듈의 이름은 requestHandlers입니다. 먼저 start() 및 upload()라는 두 가지 자리 표시자 함수를 추가합니다.

requestHandlers.js 코드는 다음과 같습니다.

코드 복사 코드는 다음과 같습니다.

함수 시작() {
console.log("/star에 접근할 때 호출됩니다.");
}

함수 업로드() {
console.log("/upload에 접근할 때 호출됩니다.");
}

수출.시작 = 시작;
수출.업로드 = 업로드;

실제 애플리케이션에서는 요청 핸들러의 수가 계속해서 증가할 것이며, 새로운 URL이나 요청 핸들러가 있을 때마다 경로에서 요청을 완료할 필요는 없습니다.

핸들러에 매핑하고 계속해서 던지는 것입니다.

또한 라우팅에서 if request == x 그런 다음 핸들러 y를 호출하는 경우가 많아 코드가 지저분하고 비전문적으로 보일 수 있기를 원하지 않습니다.

여기서는 연관 배열의 개념을 사용하여 이 요구 사항을 처리합니다. 객체를 통해 일련의 요청 핸들러를 전달하고 이 객체를 느슨하게 결합된 방식으로 Route() 함수에 삽입해야 합니다.

먼저 이 개체를 기본 파일 index.js에 소개합니다.

코드 복사 코드는 다음과 같습니다.

var 서버 = require("./server");
var router = require("./router");
var requestHandlers = require("./requestHandlers");

var 핸들 = {};
핸들["/"] = requestHandlers.start;
핸들["/start"] = requestHandlers.start;
핸들["/upload"] = requestHandlers.upload;

server.start(router.route, 핸들);

예를 들어, /show 매핑을 추가하려면 handler["/show"] requestHandlers.show만 추가하면 됩니다.

하하, 이렇게 하면 코드가 더 간결해지고 질서정연해지나요? !

다음으로 핸들 개체를 서버에 전달하고 다음과 같이 server.js를 수정합니다.

코드 복사 코드는 다음과 같습니다.

var http = require("http");
var url = require("url");
함수 시작(경로, 핸들) {
함수 onRequest(요청, 응답) {
var 경로명 = url.parse(request.url).pathname;
Console.log("" pathname "에 대한 요청이 수신되었습니다.");
경로(핸들, 경로명);
response.writeHead(200, {"Content-Type": "text/plain"});
response.write("Hello World");
response.end();
}
http.createServer(onRequest).listen(8888);
console.log("서버가 시작되었습니다.");
}
수출.시작 = 시작;

route.js 파일에서 Route() 함수를 이에 맞게 수정합니다.

코드 복사 코드는 다음과 같습니다.

함수 경로(핸들, 경로명) {
console.log("pathname에 대한 요청을 라우팅하려고 합니다.");
if (typeof 핸들[경로 이름] === '함수') {
핸들[경로명]();
} 그 밖의 {
console.log("경로명에 대한 요청 핸들러를 찾을 수 없습니다.");
}
}
수출.경로 = 경로;

핸들 객체를 서버에 매개변수로 전달하고, 이를 라우터가 수신합니다. 마지막으로 라우터는 현재 경로에 해당하는 요청 핸들러가 존재하는지 확인하고 해당 함수를 호출합니다.

연관 배열에서 요소를 가져오는 것과 동일한 방식으로 전달된 개체에서 요청 처리 기능을 가져올 수 있으므로 다음과 같은 느낌이 드는 간단하고 부드러운 표현인 Handle[경로명]();을 갖게 됩니다. 앞에서 언급한 내용: "이 길을 안내해 주세요."

이러한 방식으로 다양한 요청을 다르게 처리할 수 있습니다.

다음 섹션에서는 서버가 실제 피드백 작업을 수행할 수 있도록 코드를 추가로 수정하겠습니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.