輕松創(chuàng)建nodejs服務(wù)器(5):事件處理程序
為了對(duì)不同請(qǐng)做出不同的反饋,我們引入一個(gè)事件處理器的模塊。
該模塊命名為 requestHandlers,我們先添加start() 和 upload()兩個(gè)占位函數(shù)。
requestHandlers.js 代碼如下:
function start() {
console.log("訪問(wèn)/star時(shí)調(diào)用這個(gè)。");
}
function upload() {
console.log("訪問(wèn)/upload時(shí)調(diào)用這個(gè)。");
}
exports.start = start;
exports.upload = upload;
在真實(shí)的應(yīng)用中,請(qǐng)求處理程序的數(shù)量會(huì)不斷增加,我們當(dāng)然不想每次有一個(gè)新的URL或請(qǐng)求處理程序時(shí),都要為了在路由里完成請(qǐng)求
到處理程序的映射而反復(fù)折騰。
除此之外,我們也不想在在路由里有一大堆if request == x then call handler y,這樣會(huì)讓代碼看起來(lái) 很雜亂、很不專業(yè)的感覺(jué)。
這里我將使用關(guān)聯(lián)數(shù)組的概念來(lái)處理這個(gè)需求,我們將一系列請(qǐng)求處理程序通過(guò)一個(gè)對(duì)象來(lái)傳遞,并且需要使用松耦合的方式將這個(gè)對(duì)象注入到route()函數(shù)中。
我們先將這個(gè)對(duì)象引入到主文件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);
比如我想加一個(gè)/show的映射,直接添加一句 handle["/show"] requestHandlers.show;就可以了;
哈哈,這樣一來(lái)代碼是不是簡(jiǎn)潔有秩序多了?!
接下來(lái)我們將handle對(duì)象傳給服務(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;
對(duì)應(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對(duì)象作為參數(shù)傳給服務(wù)器,再由路由接收,最后由路由來(lái)判斷當(dāng)前路徑對(duì)應(yīng)的請(qǐng)求處理程序存在否,存在的話就調(diào)用對(duì)應(yīng)的函數(shù)。
我們可以用從關(guān)聯(lián)數(shù)組中獲取元素一樣的方式從傳遞的對(duì)象中獲取請(qǐng)求處理函數(shù),因此就有了簡(jiǎn)潔流暢的形如handle[pathname]();的表達(dá)式,這個(gè)感覺(jué)就像在前方中提到的那樣:“嗨,請(qǐng)幫我處理了這個(gè)路徑”。
這樣一來(lái),我們就可以根據(jù)不同請(qǐng)求作出不同的處理了。
下一節(jié)我們將進(jìn)一步改造代碼,讓服務(wù)器作出一些實(shí)際的反饋操作。
相關(guān)文章
說(shuō)說(shuō)node中的可讀流和可寫流的區(qū)別
這篇文章主要介紹了說(shuō)說(shuō)node中的可讀流和可寫流的區(qū)別,詳細(xì)的介紹了可讀流和可寫流,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-06-06npm報(bào)版本與node.js不匹配問(wèn)題及解決
這篇文章主要介紹了npm報(bào)版本與node.js不匹配問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06Node升級(jí)后vue項(xiàng)目node-sass報(bào)錯(cuò)問(wèn)題及解決
這篇文章主要介紹了Node升級(jí)后vue項(xiàng)目node-sass報(bào)錯(cuò)問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03Node+Express搭建HTTPS服務(wù)的實(shí)現(xiàn)
最近開發(fā)需要搭建一個(gè)https的服務(wù),正好最近在用nodejs和express,本文章主要介紹了Node+Express搭建HTTPS服務(wù)的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-12-12NodeJS之優(yōu)缺點(diǎn)及適用場(chǎng)景討論
這篇文章主要介紹了NodeJS之優(yōu)缺點(diǎn)及適用場(chǎng)景討論,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10深入剖析Express cookie-parser中間件實(shí)現(xiàn)示例
本篇文章主要介紹了深入剖析Express cookie-parser中間件實(shí)現(xiàn)示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-02-02sublime text配置node.js調(diào)試(圖文教程)
下面小編就為大家分享一篇sublime text配置node.js調(diào)試(圖文教程),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-11-11