緊接上一節(jié),我們來分析一下代碼:
第一行請求(require)Node.js自帶的 http 模塊,并且把它賦值給 http 變量。
接下來我們調(diào)用http模塊提供的函數(shù): createServer 。
這個函數(shù)會返回一個對象,這個對象有一個叫做 listen 的方法,這個方法有一個數(shù)值參數(shù),指定這個HTTP服務器監(jiān)聽的端口號。
為了提高可讀性,我們來改一下這段代碼。
原來的代碼:
可以改寫成:
我們定義了一個onRequest()函數(shù),并將它作為參數(shù)傳給createServer,類似回調(diào)函數(shù)。
我們給某個方法傳遞了一個函數(shù),這個方法在有相應事件發(fā)生時調(diào)用這個函數(shù)來進行回調(diào),我們把這叫做基于事件驅(qū)動的回調(diào)。
接下來我們看一下onRequest() 的主體部分,當回調(diào)啟動,我們的 onRequest() 函數(shù)被觸發(fā)的時候,有兩個參數(shù)被傳入: request 和 response 。
request : 收到的請求信息;
response : 收到請求后做出的響應。
所以這段代碼所執(zhí)行的操作就是:
當收到請求時,
1、使用 response.writeHead() 函數(shù)發(fā)送一個HTTP狀態(tài)200 和 HTTP頭的內(nèi)容類型(content-type)
2、使用 response.write() 函數(shù)在HTTP相應主體中發(fā)送文本“Hello World”。
3、調(diào)用 response.end() 完成響應。
這樣分析,是不是加深了你對這段代碼的理解呢?
下一節(jié)我們來了解一下,nodejs的代碼模塊化。
新聞熱點
疑難解答