從零開始學(xué)習(xí)Node.js系列教程二:文本提交與顯示方法
本文實(shí)例講述了Node.js文本提交與顯示方法。分享給大家供大家參考,具體如下:
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);
server.js
var http = require("http");
var url = require("url");
function start(route, handle) {
function onRequest(request, response) {
var postData = "";
var pathname = url.parse(request.url).pathname;
console.log("Request for " + pathname + " received.");
request.setEncoding("utf8");
request.addListener("data", function(postDataChunk) {
postData += postDataChunk;
console.log("Received POST data chunk '"+
postDataChunk + "'.");
});
request.addListener("end", function() {
console.log("data received ending" + pathname);
route(handle, pathname, response, postData);
});
}
http.createServer(onRequest).listen(8888);
console.log("Server has started.");
}
exports.start = start;
requestHandlers.js
var querystring = require("querystring");
function start(response, postData) {
console.log("Request handler 'start' was called.");
var body = '<html>'+
'<head>'+
'<meta http-equiv="Content-Type" content="text/html; '+
'charset=UTF-8" />'+
'</head>'+
'<body>'+
'<form action="/upload" method="post">'+
'<textarea name="text" rows="20" cols="60"></textarea>'+
'<input type="submit" value="Submit text" />'+
'</form>'+
'</body>'+
'</html>';
response.writeHead(200, {"Content-Type": "text/html"});
response.write(body);
response.end();
}
function upload(response, postData) {
console.log("Request handler 'upload' was called.");
response.writeHead(200, {"Content-Type": "text/plain"});
response.write("You've sent the text: "+
querystring.parse(postData).text);
response.end();
}
exports.start = start;
exports.upload = upload;
router.js
function route(handle, pathname, response, postData) {
console.log("About to route a request for " + pathname);
if (typeof handle[pathname] === 'function') {
handle[pathname](response, postData);
} else {
console.log("No request handler found for " + pathname);
response.writeHead(404, {"Content-Type": "text/plain"});
response.write("404 Not found");
response.end();
}
}
exports.route = route;
result:





知識點(diǎn):
require和exports的用法:
index.js中代碼
var Hello = require('.hello');
hello = new Hello();
hello.setName('Joey');
hello.sayHello();
hello.js中代碼
function Hello(){
var name;
this.setName = function(thyName){
name = thyName;
}
this.sayHello = function(){
console.log('Hello ' + name);
}
}
//exports.Hello = Hello; //此時我們在其他文件中需要通過 require('./hello').Hello來獲取Hello對象,這種寫法有點(diǎn)冗余
module.exports = Hello; //輸出的就是Hello對象本身,不是上面的exports,上面的是暴露.Hello,.Hello賦予了Hello對象
希望本文所述對大家nodejs程序設(shè)計(jì)有所幫助。
- node.js中的http.get方法使用說明
- node.js中的http.createServer方法使用說明
- node.js中的http.response.addTrailers方法使用說明
- node.js中的http.response.writeHead方法使用說明
- node.js中的http.request方法使用說明
- node.js+Ajax實(shí)現(xiàn)獲取HTTP服務(wù)器返回?cái)?shù)據(jù)
- 從零開始學(xué)習(xí)Node.js系列教程之SQLite3和MongoDB用法分析
- 從零開始學(xué)習(xí)Node.js系列教程六:EventEmitter發(fā)送和接收事件的方法示例
- 從零開始學(xué)習(xí)Node.js系列教程五:服務(wù)器監(jiān)聽方法示例
- 從零開始學(xué)習(xí)Node.js系列教程四:多頁面實(shí)現(xiàn)數(shù)學(xué)運(yùn)算的client端和server端示例
- 從零開始學(xué)習(xí)Node.js系列教程四:多頁面實(shí)現(xiàn)的數(shù)學(xué)運(yùn)算示例
- 從零開始學(xué)習(xí)Node.js系列教程三:圖片上傳和顯示方法示例
- 從零開始學(xué)習(xí)Node.js系列教程一:http get和post用法分析
- 從零開始學(xué)習(xí)Node.js系列教程之設(shè)置HTTP頭的方法示例
相關(guān)文章
Node.js基于node-schedule實(shí)現(xiàn)定時任務(wù)的操作步驟
實(shí)際工作中,可能會遇到定時清除某個文件夾內(nèi)容,定時發(fā)送消息或發(fā)送郵件給指定用戶,定時導(dǎo)出某些數(shù)據(jù)等,node-schedule是一個非常不錯的npm包,可以幫助我們快速的創(chuàng)建和管理定時任務(wù),所以本文介紹了Node.js基于node-schedule實(shí)現(xiàn)定時任務(wù)的操作步驟,需要的朋友可以參考下2024-09-09
nodejs基于express實(shí)現(xiàn)文件上傳的方法
這篇文章主要介紹了nodejs基于express實(shí)現(xiàn)文件上傳的方法,結(jié)合實(shí)例形式分析了nodejs基于express框架實(shí)現(xiàn)文件上傳功能的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下2018-03-03
nodejs結(jié)合Socket.IO實(shí)現(xiàn)websocket即時通訊
websocket 是一種網(wǎng)絡(luò)通信協(xié)議,一般用來進(jìn)行實(shí)時通信會使用到。本文主要介紹了nodejs結(jié)合Socket.IO實(shí)現(xiàn)websocket即時通訊 ,感興趣的可以了解一下2021-11-11
史上無敵詳細(xì)的Node.Js環(huán)境搭建步驟記錄
Node.js是一個事件驅(qū)動I/O服務(wù)端JavaScript環(huán)境,由于其擁有異步非阻塞、環(huán)境搭建簡單、實(shí)踐應(yīng)用快等特性,使得其在新一代編程開發(fā)中更為流行,下面這篇文章主要給大家介紹了關(guān)于Node.Js環(huán)境搭建步驟記錄的相關(guān)資料,需要的朋友可以參考下2023-03-03
Node.js之網(wǎng)絡(luò)通訊模塊實(shí)現(xiàn)淺析
本篇文章主要介紹了Node.js之網(wǎng)絡(luò)通訊模塊實(shí)現(xiàn)淺析,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-04-04

