Nodejs.1

參考內(nèi)容:
Node.js REPL(交互式解釋器)
C/C++之回調(diào)函數(shù)
注意 - 在nodejs網(wǎng)頁(yè)中使用中文時(shí)需要保證兩點(diǎn)

  • .js文件以UTF8格式保存栓袖;
  • 在HTML Head中需要設(shè)置charset=utf-8傲绣,如使用
    response.writeHead(200, {'Content-Type':'text/html;charset=utf-8'}); 進(jìn)行設(shè)置。

一霞赫、Node.js REPL(交互式解釋器)

Node的交互式解釋器可以很好地調(diào)試Javascript代碼

  1. 啟動(dòng)Node終端
$ node
>
  • 簡(jiǎn)單表達(dá)式運(yùn)算
$ node
> 1+4
5
> 5/2
2.5
> 3*6
18
> 4-1
3
> 1+(2*3)-4
3
>
  • 使用變量
    變量聲明使用var關(guān)鍵字,如果沒(méi)有使用var關(guān)鍵字肥矢,變量會(huì)直接打印出來(lái)端衰;使用var關(guān)鍵字的變量,可以使用console.log()輸出甘改。
$ node
> x = 10
10
> var y = 10
undefined
> x + y
20
> console.log("Hello World")
Hello World
undefined
> console.log(y)
10
undefined
>
  • 多行表達(dá)式
    類似JavaScript旅东,執(zhí)行一個(gè)do-while循環(huán)。...系統(tǒng)自動(dòng)生成十艾,Node自動(dòng)檢測(cè)是否為連續(xù)表達(dá)式抵代。
$ node
> var x = 0
undefined
> do {
... x ++;
... console.log("x: " + x);
... } while (x < 5);
x: 1
x: 2
x: 3
x: 4
x: 5
undefined
>
  • 下劃線(_)變量
    可以使用下劃線獲取表達(dá)式的運(yùn)算結(jié)果。
$ node
> var x = 10
undefined
> var y = 20
undefined
> x + y
30
> var sum = _
undefined
> console.log(sum)
30
undefined
>
REPL命令
ctrl + c  #退出當(dāng)前終端
ctrl + c按下兩次  #退出Node REPL
ctrl + d  #退出Node REPL
向上/向下 鍵  #查看輸入的歷史命令
tab 鍵  #列出當(dāng)前命令
.help  #列出使用命令
.break  #退出多行表達(dá)式
.clear  #退出多行表達(dá)式
.save filename  #保存當(dāng)前的Node REPL會(huì)話到指定文件
.load filename  #載入當(dāng)前Node REPL會(huì)話的文件內(nèi)容

二忘嫉、Node.js回調(diào)函數(shù)

Node.js異步編程直接體現(xiàn)就是回調(diào)荤牍。回調(diào)函數(shù)在完成任務(wù)后會(huì)被調(diào)用庆冕,Node使用了大量的回調(diào)函數(shù)康吵,所有API都支持回調(diào)函數(shù)。

阻塞代碼實(shí)例
  1. 創(chuàng)建一個(gè)1.2.input.txt文本访递,內(nèi)容如下(注意需要使用UTF8編碼格式保存晦嵌,否則會(huì)中文亂碼)
Hello, I'm input.txt!這是一個(gè)Input.txt文件!
  • 創(chuàng)建一個(gè)1.2.main.js文件,代碼如下(同樣以UTF8格式保存,我使用的編輯器是NotePad++惭载,有修改編碼格式的功能)
var fs = require("fs");
var data = fs.readFileSync('1.2.input.txt');
console.log(data.toString());
console.log("程序執(zhí)行結(jié)束旱函!");
  • 執(zhí)行以上代碼,結(jié)果如下:


    執(zhí)行node 1.2.main.js
非阻塞代碼實(shí)例
  1. 文本文件1.2.input.txt與之前相同棕兼;
  • 修改1.2.main.js內(nèi)容陡舅,如下:
var fs = require("fs");
fs.readFile('1.2.input.txt', function (err, data) {
    if (err) return console.error(err);
    console.log(data.toString());
});
console.log("程序執(zhí)行結(jié)束!");
  • 執(zhí)行以上代碼伴挚,結(jié)果如下:


    執(zhí)行node 1.2.main.js

可以看出非阻塞代碼不需要等待文件讀取完即可執(zhí)行靶衍,不需要按照順序進(jìn)行,所以如果需要處理回調(diào)函數(shù)的參數(shù)茎芋,就需要寫在回調(diào)函數(shù)內(nèi)颅眶。

三、Node.js事件循環(huán)

  • Node.js是單進(jìn)程單線程應(yīng)用程序田弥,但通過(guò)事件和回調(diào)支持并發(fā)涛酗,所以性能高;
  • Node.js的每一個(gè)API都是異步的偷厦,并作為一個(gè)獨(dú)立線程運(yùn)行商叹,使用異步函數(shù)調(diào)用,并處理并發(fā)只泼;
  • Node.js基本所有的事件機(jī)制都是用設(shè)計(jì)模式中的觀察者模式實(shí)現(xiàn)剖笙;
  • Node.js單線程類似進(jìn)入一個(gè)while(true)的事件循環(huán),直到?jīng)]有事件觀察者退出请唱,每個(gè)異步事件都生成一個(gè)事件觀察者弥咪,如果有事件發(fā)生就調(diào)用該回調(diào)函數(shù)。
事件驅(qū)動(dòng)程序

Node.js使用事件驅(qū)動(dòng)模型十绑,當(dāng)web server接收到請(qǐng)求聚至,就把它關(guān)閉然后進(jìn)行處理,然后服務(wù)下一個(gè)web請(qǐng)求本橙;
當(dāng)這個(gè)請(qǐng)求完成扳躬,它被放回處理隊(duì)列,當(dāng)?shù)竭_(dá)隊(duì)列開(kāi)頭甚亭,結(jié)果被返回給用戶贷币;
web server一直接受請(qǐng)求而不等待任何讀寫操作(稱之為非阻塞IO或事件驅(qū)動(dòng)IO),在事件驅(qū)動(dòng)模型中狂鞋,會(huì)生成一個(gè)主循環(huán)監(jiān)聽(tīng)事件片择,檢測(cè)到事件時(shí)觸發(fā)回調(diào)函數(shù)潜的。


事件驅(qū)動(dòng)
  1. Node.js有多個(gè)內(nèi)置事件骚揍,可通過(guò)引入events模塊,并通過(guò)實(shí)例化
    EventEmitter 類來(lái)綁定和監(jiān)聽(tīng)事件,如下:
// 引入events模塊
var events = require('events');
// 創(chuàng)建eventEmitter對(duì)象
var eventEmitter = new events.EventEmitter();

以下綁定事件處理程序:

// 綁定事件及事件的處理程序
eventEmitter.on('eventName', eventHandler);

通過(guò)程序觸發(fā)事件:

// 觸發(fā)事件
eventEmitter.emit('eventName');
  • 實(shí)例
    創(chuàng)建1.3.1.main.js文件信不,代碼如下:
// 引入events模塊
var events = require('events');
// 創(chuàng)建eventEmitter對(duì)象
var eventEmitter = new events.EventEmitter();
// 創(chuàng)建事件處理程序
var connectHandler = function connected() {
    console.log('連接成功嘲叔。');
    // 觸發(fā)data_received事件
    eventEmitter.emit('data_received');
}
// 綁定connection事件處理程序
eventEmitter.on('connection', connectHandler);
// 使用匿名函數(shù)綁定data_received事件
eventEmitter.on('data_received', function() {
    console.log('數(shù)據(jù)接收成功。');
});
// 觸發(fā)connection事件
eventEmitter.emit('connection');
console.log("程序執(zhí)行完畢抽活。");
執(zhí)行結(jié)果
Node應(yīng)用程序的工作過(guò)程

在Node應(yīng)用中硫戈,執(zhí)行異步操作的函數(shù)將回調(diào)函數(shù)作為最后一個(gè)參數(shù),回調(diào)函數(shù)接受錯(cuò)誤對(duì)象作為第一個(gè)參數(shù)下硕。

  1. 繼續(xù)使用之前的1.2.input.txt文本文件丁逝;
  • 創(chuàng)建1.3.2.main.js,內(nèi)容如下:
var fs = require("fs");
fs.readFile('1.2.input.txt', function (err, data) {
    if (err) {
        console.log(err.stack);
        return ;
    }
    console.log(data.toString());
});
console.log("程序執(zhí)行完畢梭姓!");

以上程序fs.readFile()是異步函數(shù)用于讀取文件霜幼。如果讀取中發(fā)生錯(cuò)誤,err對(duì)象會(huì)輸出錯(cuò)誤信息誉尖;如果不發(fā)生錯(cuò)誤罪既,文件內(nèi)容通過(guò)回調(diào)函數(shù)輸出。以上代碼執(zhí)行結(jié)果如下:


執(zhí)行結(jié)果
  • 如果沒(méi)有1.2.input.txt文件铡恕,執(zhí)行結(jié)果如下琢感,輸出了錯(cuò)誤信息:


    沒(méi)有txt文本時(shí)執(zhí)行結(jié)果
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市探熔,隨后出現(xiàn)的幾起案子驹针,更是在濱河造成了極大的恐慌,老刑警劉巖祭刚,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件牌捷,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡涡驮,警方通過(guò)查閱死者的電腦和手機(jī)暗甥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)捉捅,“玉大人撤防,你說(shuō)我怎么就攤上這事“艨冢” “怎么了寄月?”我有些...
    開(kāi)封第一講書人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)无牵。 經(jīng)常有香客問(wèn)我漾肮,道長(zhǎng),這世上最難降的妖魔是什么茎毁? 我笑而不...
    開(kāi)封第一講書人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任克懊,我火速辦了婚禮忱辅,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘谭溉。我一直安慰自己墙懂,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布扮念。 她就那樣靜靜地躺著损搬,像睡著了一般。 火紅的嫁衣襯著肌膚如雪柜与。 梳的紋絲不亂的頭發(fā)上巧勤,一...
    開(kāi)封第一講書人閱讀 51,727評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音弄匕,去河邊找鬼踢关。 笑死,一個(gè)胖子當(dāng)著我的面吹牛粘茄,可吹牛的內(nèi)容都是我干的签舞。 我是一名探鬼主播,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼柒瓣,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼儒搭!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起芙贫,我...
    開(kāi)封第一講書人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤搂鲫,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后磺平,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體魂仍,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年拣挪,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了擦酌。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡菠劝,死狀恐怖赊舶,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情赶诊,我是刑警寧澤笼平,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站舔痪,受9級(jí)特大地震影響寓调,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜锄码,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一夺英、第九天 我趴在偏房一處隱蔽的房頂上張望鸠珠。 院中可真熱鬧,春花似錦秋麸、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至亲族,卻和暖如春炒考,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背霎迫。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工斋枢, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人知给。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓瓤帚,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親涩赢。 傳聞我的和親對(duì)象是個(gè)殘疾皇子戈次,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容