這篇文章主要介紹了nodejs中實現路由功能,顧名思義,路由指的就是我們要針對不同的URL有不同的處理方式,本文將教你在node.js中實現路由功能,需要的朋友可以參考下
初學Node,發現了與自己之前的觀點完全不同的場面──你眼中的JavaScript,是做什麼用的呢?特效? or 只是與客戶端的互動?可以說,JavaScript最早是運行在瀏覽器中的,然而你要這樣想,瀏覽器只是你提供了一個上下文(context),它定義了使用JavaScript可以做什麼,這裡可以想成類似的一個企業,企業定義了你可以在這裡做什麼,但是並沒有說太多關於JavaScript語言本身可以做什麼。事實上,作為一門完整的語言,JavaScript可以使用在不同的脈絡中,體現出不同的能力。這裡所講到的Nodejs其實說白了就是提供 的一個上下文,一個運行環境,它允許在後端(脫離瀏覽器環境)來運行JavaScript程式碼。
路由選擇的核心是路由,顧名思義,路由指的就是我們要針對不同的URL有不同的處理方式,例如處理/start的業務邏輯和處理/upload模組的業務;邏輯就是不一致的。在現實的實現下,路由過程會在路由模組中“結束”,並且路由模組並不是真正者針對請求“採取行動”的模組,否則當我們的應用程式變得更為複雜的時候就將無法得到很好的擴充。
這裡我們先建立一個叫做requestHandlers的模組,對於每一個請求處理程序都新增一個佔位函數:
function start(){ console.log("Request handler 'start' was called."); function sleep(milliSeconds){ var startTime=new Date().getTime(); while(new Date().getTime()<startTime+milliSeconds); } sleep(10000); return "Hello Start"; } function upload(){ console.log("Request handler 'upload' was called."); return "Hello Upload"; } exports.start=start; exports.upload=upload;
這樣我們就可以將請求處理程序和路由模組連接起來,讓路由「有路可循」。之後我們確定將一系列請求處理程序透過一個物件來傳遞,並且需要使用鬆散耦合的方式將這個物件注入到router()函數中,主檔案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);
如上所示,將不同的URL對應到相同的請求處理程序上是容易的:只要在物件中新增一個鍵為「/」的屬性,對應requestHandlers.start即可。這樣我們就可以簡潔地設定/start和/的請求都交給start這一處理程序來處理。在完成看物件的定義後,我們將它作為額外的參數傳遞給伺服器,請參閱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"}); var content=route(handle,pathname); response.write(content); response.end(); } http.createServer(onRequest).listen(8888); console.log("Server has started."); } exports.start=start;
這樣就在start()函數中加入了handle參數,並且把handle物件當作第一個參數傳遞給了route()回呼函數,下面定義route.js:
function route(handle,pathname){ console.log("About to route a request for "+ pathname); if(typeof handle[pathname]==='function‘){ return handle[pathname](); }else{ console.log("No request handler found for "+pathname); return "404 Not Found"; } } exports.route=route;
透過以上程式碼,我們首先檢查給定的路徑對應的請求處理程序是否存在,如果存在則直接呼叫相應的函數。我們可以用從關聯數組中獲取元素一樣的方式從傳遞的對像中獲取請求處理函數,即handle[pathname]();這樣的表達式,給人一種感覺就像是在說“嗨,請你來幫我處理這個路徑。」程式運作效果如下圖:
以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!
相關推薦:
以上是nodejs中實作路由功能的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!