輕松創(chuàng)建nodejs服務(wù)器(5):事件處理程序
為了對不同請做出不同的反饋,我們引入一個事件處理器的模塊。
該模塊命名為 requestHandlers,我們先添加start() 和 upload()兩個占位函數(shù)。
requestHandlers.js 代碼如下:
function start() {
console.log("訪問/star時調(diào)用這個。");
}
function upload() {
console.log("訪問/upload時調(diào)用這個。");
}
exports.start = start;
exports.upload = upload;
在真實的應(yīng)用中,請求處理程序的數(shù)量會不斷增加,我們當(dāng)然不想每次有一個新的URL或請求處理程序時,都要為了在路由里完成請求
到處理程序的映射而反復(fù)折騰。
除此之外,我們也不想在在路由里有一大堆if request == x then call handler y,這樣會讓代碼看起來 很雜亂、很不專業(yè)的感覺。
這里我將使用關(guān)聯(lián)數(shù)組的概念來處理這個需求,我們將一系列請求處理程序通過一個對象來傳遞,并且需要使用松耦合的方式將這個對象注入到route()函數(shù)中。
我們先將這個對象引入到主文件index.js中:
var server = require("./server");
var router = require("./router");
var requestHandlers = require("./requestHandlers");
var handle = {};
handle["/"] = requestHandlers.start;
handle["/start"] = requestHandlers.start;
handle["/upload"] = requestHandlers.upload;
server.start(router.route, handle);
比如我想加一個/show的映射,直接添加一句 handle["/show"] requestHandlers.show;就可以了;
哈哈,這樣一來代碼是不是簡潔有秩序多了?!
接下來我們將handle對象傳給服務(wù)器,server.js修改如下:
var http = require("http");
var url = require("url");
function start(route, handle) {
function onRequest(request, response) {
var pathname = url.parse(request.url).pathname;
console.log("Request for " + pathname + " received.");
route(handle, pathname);
response.writeHead(200, {"Content-Type": "text/plain"});
response.write("Hello World");
response.end();
}
http.createServer(onRequest).listen(8888);
console.log("Server has started.");
}
exports.start = start;
對應(yīng)地修改route.js文件中修改route()函數(shù):
function route(handle, pathname) {
console.log("About to route a request for " + pathname);
if (typeof handle[pathname] === 'function') {
handle[pathname]();
} else {
console.log("No request handler found for " + pathname);
}
}
exports.route = route;
我們將handle對象作為參數(shù)傳給服務(wù)器,再由路由接收,最后由路由來判斷當(dāng)前路徑對應(yīng)的請求處理程序存在否,存在的話就調(diào)用對應(yīng)的函數(shù)。
我們可以用從關(guān)聯(lián)數(shù)組中獲取元素一樣的方式從傳遞的對象中獲取請求處理函數(shù),因此就有了簡潔流暢的形如handle[pathname]();的表達式,這個感覺就像在前方中提到的那樣:“嗨,請幫我處理了這個路徑”。
這樣一來,我們就可以根據(jù)不同請求作出不同的處理了。
下一節(jié)我們將進一步改造代碼,讓服務(wù)器作出一些實際的反饋操作。
相關(guān)文章
Node+Express搭建HTTPS服務(wù)的實現(xiàn)
最近開發(fā)需要搭建一個https的服務(wù),正好最近在用nodejs和express,本文章主要介紹了Node+Express搭建HTTPS服務(wù)的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下2023-12-12
深入剖析Express cookie-parser中間件實現(xiàn)示例
本篇文章主要介紹了深入剖析Express cookie-parser中間件實現(xiàn)示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-02-02
sublime text配置node.js調(diào)試(圖文教程)
下面小編就為大家分享一篇sublime text配置node.js調(diào)試(圖文教程),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-11-11

