從零開始學(xué)習(xí)Node.js系列教程二:文本提交與顯示方法
更新時間:2017年04月13日 10:33:19 作者:MIN飛翔
這篇文章主要介紹了Node.js文本提交與顯示方法,結(jié)合實例形式分析了nodejs基于http的文本提交、傳輸與顯示相關(guān)操作技巧,需要的朋友可以參考下
本文實例講述了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:
知識點:
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對象,這種寫法有點冗余 module.exports = Hello; //輸出的就是Hello對象本身,不是上面的exports,上面的是暴露.Hello,.Hello賦予了Hello對象
希望本文所述對大家nodejs程序設(shè)計有所幫助。
您可能感興趣的文章:
- 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實現(xiàn)獲取HTTP服務(wù)器返回數(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系列教程四:多頁面實現(xiàn)數(shù)學(xué)運算的client端和server端示例
- 從零開始學(xué)習(xí)Node.js系列教程四:多頁面實現(xiàn)的數(shù)學(xué)運算示例
- 從零開始學(xué)習(xí)Node.js系列教程三:圖片上傳和顯示方法示例
- 從零開始學(xué)習(xí)Node.js系列教程一:http get和post用法分析
- 從零開始學(xué)習(xí)Node.js系列教程之設(shè)置HTTP頭的方法示例
相關(guān)文章
Node.js基于node-schedule實現(xiàn)定時任務(wù)的操作步驟
實際工作中,可能會遇到定時清除某個文件夾內(nèi)容,定時發(fā)送消息或發(fā)送郵件給指定用戶,定時導(dǎo)出某些數(shù)據(jù)等,node-schedule是一個非常不錯的npm包,可以幫助我們快速的創(chuàng)建和管理定時任務(wù),所以本文介紹了Node.js基于node-schedule實現(xiàn)定時任務(wù)的操作步驟,需要的朋友可以參考下2024-09-09nodejs基于express實現(xiàn)文件上傳的方法
這篇文章主要介紹了nodejs基于express實現(xiàn)文件上傳的方法,結(jié)合實例形式分析了nodejs基于express框架實現(xiàn)文件上傳功能的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下2018-03-03nodejs結(jié)合Socket.IO實現(xiàn)websocket即時通訊
websocket 是一種網(wǎng)絡(luò)通信協(xié)議,一般用來進行實時通信會使用到。本文主要介紹了nodejs結(jié)合Socket.IO實現(xiàn)websocket即時通訊 ,感興趣的可以了解一下2021-11-11Node.js之網(wǎng)絡(luò)通訊模塊實現(xiàn)淺析
本篇文章主要介紹了Node.js之網(wǎng)絡(luò)通訊模塊實現(xiàn)淺析,具有一定的參考價值,有興趣的可以了解一下。2017-04-04