Nodejs學習筆記

Node.js 是單進程單線程應用程序,但是通過事件和回調支持并發,所以性能非常高。
nodejs由以下模塊組成:
引入 required 模塊:我們可以使用 require 指令來載入 Node.js 模塊。
創建服務器:服務器可以監聽客戶端的請求,類似于 Apache 、Nginx 等 HTTP 服務器。
接收請求與響應請求 服務器很容易創建,客戶端可以使用瀏覽器或終端發送 HTTP 請求,服務器接收請求后返回響應數據。

創建服務器
首先要引入http模塊
var http = require("http");
通過
http.createServer() 方法創建服務器
demo:
var http = require('http');http.createServer(function (request, response) { // 發送 HTTP 頭部 // HTTP 狀態值: 200 : OK // 內容類型: text/plain response.writeHead(200, {'Content-Type': 'text/plain'}); // 發送響應數據 "Hello World" response.end('Hello World\n');}).listen(8888);// 終端打印如下信息console.log('Server running at http://127.0.0.1:8888/');
寫入數據可以使用write()
response.write("Hello World");
response.write(" IAM LQ");
response.write(data.toString());
response.end();

使用package.json
npm init 去創建

Node.js REPL交互式解釋器
http://www.runoob.com/nodejs/nodejs-repl.html

Nodejs 回調函數
demo:
var http=require('http');//http服務
var fs = require("fs");//讀取文件
http.createServer(function(request,response){
response.writeHead(200,{'Content-Type':'text/plain'});
//讀取文件信息 將返回值 給response
//var data = fs.readFileSync('input.txt'); 這種方式 是 同步
fs.readFile('message.txt', function (err, data) {
if (err) return console.error(err);
response.end(data.toString());
});
}).listen(8888);

console.log('運行在 http://localhost:"8888');

Nodejs 事件循環
綁定和監聽事件 需要引入events 模塊 并且通過EventEmitter 類來綁定和監聽事件
eventEmitter.on('你起的名字',function(){
//這里是這個事件對應的do something
})
eventEmitter.emit('你起的名字');//這樣子去執行你寫好的事件

demo:
// 引入 events 模塊
var events = require('events');
// 創建 eventEmitter 對象
var eventEmitter = new events.EventEmitter();

//創建鏈接函數
eventEmitter.on('connection',function(){
console.log('鏈接成功');
eventEmitter.emit('data_received');
});

// 使用匿名函數綁定 data_received 事件
eventEmitter.on('data_received', function(){
console.log('數據接收成功。');
});

// 觸發 connection 事件
eventEmitter.emit('connection');

console.log("程序執行完畢。");

Buffer緩沖區
專門存放二進制數據
new Buffer創建buffer對象實例 write返回實際寫入的大小
寫入demo:
var buf = new Buffer(256);
var len = buf.write("www.runoob.cn",0,8,"utf8");//數據,開始下標,能存多少位,編碼方式

console.log("寫入字節數 : "+ len);//8
存入漢子并且打印出來:
var buf = new Buffer('你好我是數據');

console.log(buf.toString());
合并buffer:
var buffer1 = new Buffer('菜鳥教程 ');var buffer2 = new Buffer('www.runoob.com');var buffer3 = Buffer.concat([buffer1,buffer2]);console.log("buffer3 內容: " + buffer3.toString());

Node.js Stream(流)
http 服務器發起請求的request 對象就是一個 Stream

createWriteStream//寫入流
createReadStream//讀取流
創建對象并且指向文件對象
var readerStream = fs.createReadStream('input.txt');
var writerStream = fs.createWriteStream('output.txt');
寫入數據 并且定義編碼規范
var data='我是寫入的數據'
writerStream.write(data,'UTF8');
讀取數據并且打印
// 設置編碼為 utf8。
var data='';
readerStream.setEncoding('utf8');
// 讀取數據并且打印
readerStream.on('data', function(data) {
data = data;
console.log(data);
});
以下是數據copy 一個文件讀取存入另一個文件
var fs = require("fs");

// 創建一個可讀流
var readerStream = fs.createReadStream('message.txt');

// 創建一個可寫流
var writerStream = fs.createWriteStream('book.txt');

// 管道讀寫操作
// 讀取 input.txt 文件內容,并將內容寫入到 output.txt 文件中
readerStream.pipe(writerStream);

console.log("程序執行完畢");
壓縮文件
var fs = require("fs");var zlib = require('zlib');// 壓縮 input.txt 文件為 input.txt.gzfs.createReadStream('input.txt') .pipe(zlib.createGzip()) .pipe(fs.createWriteStream('input.txt.gz')); console.log("文件壓縮完成。");
解壓文件
var fs = require("fs");var zlib = require('zlib');// 解壓 input.txt.gz 文件為 input.txtfs.createReadStream('input.txt.gz') .pipe(zlib.createGunzip()) .pipe(fs.createWriteStream('input.txt')); console.log("文件解壓完成。");

nodejs 模塊系統
優先加載原生模塊 例如http、fs、path等
var http=require('http');
module.exports=function(){} or 對象

Nodejs函數
和JS一樣

nodejs路由
我們需要的所有數據都會包含在request對象中,該對象作為onRequest()回調函數的第一個參數傳遞。但是為了解析這些數據,我們需要額外的Node.JS模塊,它們分別是url和querystring模塊。
說白了就是路徑
var pathname = url.parse('http://baidu.com/a/b?a=1').pathname;
var router=url.parse('http://baidu.com/a/b?a=1').query
response.write(pathname+" "+router);

會出現 /a/b a=1

node全局對象
response.write(__filename);D:\nodejsdemo\global.js
response.write(__dirname);D:\nodejsdemo
setTimeout(cb, ms)
clearTimeout(t)
setInterval(cb, ms)
console
process process 是一個全局變量,即 global 對象的屬性。 和系統交互要用到

nodejs常用工具 util
util 是一個Node.js 核心模塊,提供常用函數的集合,用于彌補核心JavaScript 的功能 過于精簡的不足。
用于繼承
util.inherits(child,parent)
只能繼承原型中定義的函數 即通過prototype擴展的函數
構造函數內部創造的不繼承
util.inspect任意對象轉換 為字符串的方法,通常用于調試和錯誤輸出。它至少接受一個參數 object,即要轉換的對象。
util.isArray(object)如果給定的參數 "object" 是一個數組返回true,否則返回false。
util.isRegExp(object)如果給定的參數 "object" 是一個正則表達式返回true,否則返回false。
util.isDate(object)如果給定的參數 "object" 是一個日期返回true,否則返回false。
util.isError(object)如果給定的參數 "object" 是一個錯誤對象返回true,否則返回false。

應用框架Express
安裝:npm install express --save
以下幾個重要的模塊需要與express一起安裝:
$ npm install body-parser --save$ npm install cookie-parser --save$ npm install multer --save
body-parser 處理JSON RAW Text URL編碼的數據
cookie-parser解析cookie的工具 通過req.cookies 可以取到傳來的cookie 轉成對象
multer 處理enctype="multpart/form-data"的表單數據
demo: 這里配置路由
var express=require('express');
var app=express();
app.get('/',function(req,res){
res.send('HELLO WORD2');
})
app.get('/app',function(req,res){
res.send('進入了另一個路徑');
})
var server=app.listen(8888,function(){
var host=server.address().address
var port=server.address().port
console.log("應用實例,訪問地址為 http://", host, port)
})
靜態資源
app.use(express.static('public'))
http://localhost:8888/img/2.png 就不用寫public了

設置路由 編寫接口
var express=require('express');
var app=express();
//靜態文件
app.use(express.static('public'))
//設置默認入口
app.get('/',function(req,res){
res.sendFile(__dirname+"/"+"index.html");
})
//接口
app.get('/message',function(req,res){
res.writeHead(200,{'Content-Type':'text/html;charset=utf-8'});//設置response編碼為utf-8
obj={
id:req.query.id,
name:req.query.name
}
res.end(JSON.stringify(obj));
})
var server=app.listen(8888,function(){
var host=server.address().address
var port=server.address().port
console.log("應用實例,訪問地址為 http://", host, port)
})

Post的demo:必須要引入body-parser 需要安裝依賴
var urlencodedParser = bodyParser.urlencoded({ extended: false }) 是必須的
var express=require('express');
var app=express();
var bodyParser = require('body-parser');
// 創建 application/x-www-form-urlencoded 編碼解析
var urlencodedParser = bodyParser.urlencoded({ extended: false })
//靜態文件
app.use(express.static('public'))
//設置默認入口
app.get('/',function(req,res){
res.sendFile(__dirname+"/"+"post.html");
})
//接口
app.post('/message',urlencodedParser,function(req,res){
res.writeHead(200,{'Content-Type':'text/html;charset=utf-8'});//設置response編碼為utf-8
obj={
id:req.body.id,
name:req.body.name
}
res.end(JSON.stringify(obj));
})
var server=app.listen(8888,function(){
var host=server.address().address
var port=server.address().port
console.log("應用實例,訪問地址為 http://", host, port)
})

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,763評論 6 539
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,238評論 3 428
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,823評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,604評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,339評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,713評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,712評論 3 445
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,893評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,448評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,201評論 3 357
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,397評論 1 372
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,944評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,631評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,033評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,321評論 1 293
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,128評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,347評論 2 377

推薦閱讀更多精彩內容