Node.js 的簡(jiǎn)單了解

nodeJs.jpg

看好了
這是一盞《Node.js開(kāi)發(fā)指南》的讀書筆記烁焙。

Hello World

  1. 程序文件的Hello World

    編輯一個(gè)helloworld.js文件,內(nèi)容為:

    console.log('Hello World.');
    

    保存到 ~/helloworld.js躏升。
    進(jìn)入控制臺(tái),輸入:

    $ node helloworld.js
    Hello World.
    
  2. 控制臺(tái)命令中的Hello World

    $ node -e "console.log('Hello World.');"
    Hello World.
    
  3. REPL中的Hello World

    $ node
    > console.log('Hello World');
    Hello World
    undefined
    

    進(jìn)入REPL后狼忱,可以通過(guò)連續(xù)兩次 Ctrl+c 退出膨疏。

最小的HTTP服務(wù)器

  1. 其它大部分語(yǔ)言的HTTP服務(wù)器架構(gòu)大都為“瀏覽器 - HTTP 服務(wù)器 - PHP 解釋器”的組織方式一睁。
  2. Node.jsHTTP服務(wù)器這一層抽離,直接面向?yàn)g覽器用戶。
node.js價(jià)構(gòu)

建立一個(gè)app.js文件佃却,輸入以下內(nèi)容:

var http = require('http');
     
http.createServer(function(req, res) {
res.writeHead(200, {'Content-Type': 'text/html'});
res.write('<h1>Node.js</h1>');
res.end('<p>Hello World</p>');
}).listen(3000);

console.log("Http server is listening at port 3000.");

保存到 ~/app.js者吁。執(zhí)行:$ node ~/app.js。即可在瀏覽器中通過(guò)打開(kāi) http://127.0.0.1:3000 進(jìn)行查看饲帅。

異步同步以及事件觸發(fā)

  1. 異步的文件讀取

    // readfile.js
    
    var fs = require('fs');
    
    console.log('first...');
    fs.readFile('tmp.txt', 'utf-8', function(err, data) {
        if (err) {
        console.error(err);
        }
        else {
        console.log(data);
        }
    });
    console.log('next...');
    

    以下是輸出:

    $ node readfile.js
    first...
    next...
    你是我的小呀小蘋果
    

    fs.readFile 調(diào)用時(shí)所做的工作只是將異步式 I/O 請(qǐng)求發(fā)送給了操作系統(tǒng),然后立即返回并執(zhí)行后面的語(yǔ)句复凳,執(zhí)行完以后進(jìn)入事件循環(huán)監(jiān)聽(tīng)事件。當(dāng) fs 接收到 I/O 請(qǐng)求完成的 事件時(shí)灶泵,事件循環(huán)會(huì)主動(dòng)調(diào)用回調(diào)函數(shù)以完成后續(xù)工作育八。因此我們會(huì)先看到 next...,再看到 tmp.txt 文件的內(nèi)容赦邻。

  2. 同步的文件讀取

    // readfilesync.js
    
    var fs = require('fs');
    
    console.log('first...');
    
    var data = fs.readFileSync('tmp.txt', 'utf-8');
    console.log(data);
    
    console.log('next...');
    

    輸出結(jié)果:

    $ node readfilesync.js
    first...
    你是我的小呀小蘋果
    
    next...
    
  3. 事件觸發(fā)

    // event.js
    
    var EventEmitter = require('events').EventEmitter;
    var event = new EventEmitter();
    
    event.on('some_event', function() {
        console.log('some_event occured.');
    });
    
    setTimeout(function() {
        event.emit('some_event');
    }, 1000);
    

    運(yùn)行這段代碼,1秒后控制臺(tái)輸出了 some_event occured.髓棋。其原理是 event 對(duì)象 注冊(cè)了事件 some_event 的一個(gè)監(jiān)聽(tīng)器,然后我們通過(guò) setTimeout 在1000毫秒以后向 event 對(duì)象發(fā)送事件some_event,此時(shí)會(huì)調(diào)用 some_event的監(jiān)聽(tīng)器。

模塊和包

  • 模塊(Module)和包(Package)是 Node.js 最重要的支柱深纲。開(kāi)發(fā)一個(gè)具有一定規(guī)模的程序不可能只用一個(gè)文件,通常需要把各個(gè)功能拆分仲锄、封裝,然后組合起來(lái),模塊正是為了實(shí) 現(xiàn)這種方式而誕生的。在瀏覽器 JavaScript 中,腳本模塊的拆分和組合通常使用 HTML 的 script 標(biāo)簽來(lái)實(shí)現(xiàn)湃鹊。Node.js 提供了 require 函數(shù)來(lái)調(diào)用其他模塊,而且模塊都是基于 文件的,機(jī)制十分簡(jiǎn)單儒喊。
  • 我們經(jīng)常把 Node.js 的模塊和包相提并論,因?yàn)槟K和包是沒(méi)有本質(zhì)區(qū)別的,兩個(gè)概念 也時(shí)常混用币呵。如果要辨析,那么可以把包理解成是實(shí)現(xiàn)了某個(gè)功能模塊的集合,用于發(fā)布 和維護(hù)怀愧。對(duì)使用者來(lái)說(shuō),模塊和包的區(qū)別是透明的,因此經(jīng)常不作區(qū)分。

模塊

模塊是 Node.js 應(yīng)用程序的基本組成部分,文件和模塊是一一對(duì)應(yīng)的余赢。

  1. 創(chuàng)建一個(gè)簡(jiǎn)單的模塊

    //module.js
    
    var name;
    
    exports.setName = function(thyName) {
        name = thyName
    };
    
    exports.sayHello = function() {
        console.log('Hello' + name);
    };
    

    再在同目錄下創(chuàng)建調(diào)用模塊的主文件:

    //getmodule.js
    
    var myModule = require('./module');
    myModule.setName('Arthur');
    myModule.sayHello();
    

    運(yùn)行node getmodule.js便能輸出Hello Arthur芯义。
    *看起來(lái)很像類的調(diào)用有沒(méi)有?但不是的妻柒,這也只是像而已扛拨。在getmodule.js 中,不論執(zhí)行多少次 require('./module'); 獲得的模塊都是同一個(gè)举塔。

  2. 類模塊

    //singleobject.js
    
    function Hello() {
        var name;
    
        this.setName = function(thyName) {
        name = thyName;
        };
    
        this.sayHello = function() {
        console.log('Hello ' + name);
        };
    };
    
    // 方式1.
    // exports.Hello = Hello;
    
    // 方式2.
    module.exports = Hello;
    

    singleobject.js中绑警,如果采用已被注釋掉的方式1來(lái)導(dǎo)出對(duì)象的話,需要采用require('./singleobject').Hello來(lái)獲取對(duì)象央渣,比較冗余计盒。采用方式2來(lái)輸出,就可以采用下面的方式來(lái)直接獲取了:

    //getsingleobject.js
    
    var Hello = require('./singleobject');
    
    hello = new Hello();
    hello.setName('Arthur');
    hello.sayHello();
    
  • 注意,模塊接口的唯一變化是使用 module.exports = Hello 代替了 exports.Hello= Hello芽丹。在外部引用該模塊時(shí)北启,其接口對(duì)象就是要輸出的 Hello 對(duì)象本身,而不是原先的 exports。
  • 事實(shí)上咕村,exports 本身僅僅是一個(gè)普通的空對(duì)象场钉,即 {},它專門用來(lái)聲明接口懈涛,本 質(zhì)上是通過(guò)它為模塊閉包1的內(nèi)部建立了一個(gè)有限的訪問(wèn)接口惹悄。因?yàn)樗鼪](méi)有任何特殊的地方,所以可以用其他東西來(lái)代替肩钠,譬如我們上面例子中的 Hello 對(duì)象。
  • 不可以通過(guò)對(duì) exports 直接賦值代替對(duì) module.exports 賦值暂殖。 exports 實(shí)際上只是一個(gè)和 module.exports 指向同一個(gè)對(duì)象的變量, 它本身會(huì)在模塊執(zhí)行結(jié)束后釋放,但 module 不會(huì),因此只能通過(guò)指定 module.exports 來(lái)改變?cè)L問(wèn)接口价匠。

Node.js 的包是一個(gè)目錄,其中包含一個(gè) JSON 格式的包說(shuō)明文件 package.json呛每。

  1. 作為文件夾的模塊
    創(chuàng)建一個(gè)somepackage 的文件夾踩窖,在其中創(chuàng)建 index.js :

    //somepackage/index.js
    
    exports.hello = function() {
        console.log('Hello.');
    };
    

    在somepackage之外建立getpackage.js:

    //getpackage.js
    
    var somePackage = require('./somepackage');
    
    somePackage.hello();
    

    運(yùn)行node getpackage.js 可得到Hello.

    我們使用這種方法可以把文件夾封裝為一個(gè)模塊,即所謂的包晨横。包通常是一些模塊的集 合洋腮,在模塊的基礎(chǔ)上提供了更高層的抽象,相當(dāng)于提供了一些固定接口的函數(shù)庫(kù)手形。通過(guò)定制 package.json啥供,我們可以創(chuàng)建更復(fù)雜、更完善库糠、更符合規(guī)范的包用于發(fā)布伙狐。

  2. package.json

    package.json 是 CommonJS 規(guī)定的用來(lái)描述包的文件,完全符合規(guī)范的 package.json 文 件應(yīng)該含有以下字段瞬欧。

    • name: 包的名稱贷屎,必須是唯一的,由小寫英文字母艘虎、數(shù)字和下劃線組成唉侄,不能包含空格。
    • description: 包的簡(jiǎn)要說(shuō)明野建。
    • version: 符合語(yǔ)義化版本識(shí)別規(guī)范的版本字符串属划。
    • keywords: 關(guān)鍵字?jǐn)?shù)組,通常用于搜索贬墩。
    • maintainers: 維護(hù)者數(shù)組榴嗅,每個(gè)元素要包含 name、email (可選)陶舞、web (可選)字段嗽测。
    • contributors: 貢獻(xiàn)者數(shù)組,格式與maintainers相同。包的作者應(yīng)該是貢獻(xiàn)者數(shù)組的第一個(gè)元素唠粥。
    • bugs: 提交bug的地址疏魏,可以是網(wǎng)址或者電子郵件地址。
    • licenses: 許可證數(shù)組晤愧,每個(gè)元素要包含 type (許可證的名稱)和 url (鏈接到許可證文本的地址)字段大莫。
    • repositories: 倉(cāng)庫(kù)托管地址數(shù)組,每個(gè)元素要包含 type(倉(cāng)庫(kù)的類型官份,如 git )只厘、 url (倉(cāng)庫(kù)的地址)和 path (相對(duì)于倉(cāng)庫(kù)的路徑,可選)字段舅巷。
    • dependencies: 包的依賴,一個(gè)關(guān)聯(lián)數(shù)組羔味,由包名稱和版本號(hào)組成。

一個(gè)合乎Common.JS規(guī)范的package.json文件如下:

{
"name": "mypackage",
"description": "Sample package for CommonJS. This package demonstrates the required
       elements of a CommonJS package.",
    "version": "0.7.0",
    "keywords": [
"package",
"example" ],
    "maintainers": [
       {
          "name": "Bill Smith",
          "email": "bills@example.com",
       }
    ],
    "contributors": [
       {
          "name": "BYVoid",
          "web": "http://www.byvoid.com/"
} ],
    "bugs": {
       "mail": "dev@example.com",
       "web": "http://www.example.com/bugs"
    },
    "licenses": [
       {
          "type": "GPLv2",
          "url": "http://www.example.org/licenses/gpl.html"
} ],
    "repositories": [
       {
          "type": "git",
          "url": "http://github.com/BYVoid/mypackage.git"
       }
    ],
    "dependencies": {
       "webkit": "1.2",
       "ssl": {
          "gnutls": ["1.0", "2.0"],
          "openssl": "0.9.8"
       }
} }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末钠右,一起剝皮案震驚了整個(gè)濱河市赋元,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌飒房,老刑警劉巖搁凸,帶你破解...
    沈念sama閱讀 223,002評(píng)論 6 519
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異狠毯,居然都是意外死亡护糖,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,357評(píng)論 3 400
  • 文/潘曉璐 我一進(jìn)店門垃你,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)椅文,“玉大人,你說(shuō)我怎么就攤上這事惜颇〗源蹋” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 169,787評(píng)論 0 365
  • 文/不壞的土叔 我叫張陵凌摄,是天一觀的道長(zhǎng)羡蛾。 經(jīng)常有香客問(wèn)我,道長(zhǎng)锨亏,這世上最難降的妖魔是什么痴怨? 我笑而不...
    開(kāi)封第一講書人閱讀 60,237評(píng)論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮器予,結(jié)果婚禮上浪藻,老公的妹妹穿的比我還像新娘。我一直安慰自己乾翔,他們只是感情好爱葵,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,237評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布施戴。 她就那樣靜靜地躺著,像睡著了一般萌丈。 火紅的嫁衣襯著肌膚如雪赞哗。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 52,821評(píng)論 1 314
  • 那天辆雾,我揣著相機(jī)與錄音肪笋,去河邊找鬼。 笑死度迂,一個(gè)胖子當(dāng)著我的面吹牛藤乙,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播惭墓,決...
    沈念sama閱讀 41,236評(píng)論 3 424
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼湾盒,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了诅妹?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 40,196評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤毅人,失蹤者是張志新(化名)和其女友劉穎吭狡,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體丈莺,經(jīng)...
    沈念sama閱讀 46,716評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡划煮,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,794評(píng)論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了缔俄。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片弛秋。...
    茶點(diǎn)故事閱讀 40,928評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖俐载,靈堂內(nèi)的尸體忽然破棺而出蟹略,到底是詐尸還是另有隱情,我是刑警寧澤遏佣,帶...
    沈念sama閱讀 36,583評(píng)論 5 351
  • 正文 年R本政府宣布挖炬,位于F島的核電站,受9級(jí)特大地震影響状婶,放射性物質(zhì)發(fā)生泄漏意敛。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,264評(píng)論 3 336
  • 文/蒙蒙 一膛虫、第九天 我趴在偏房一處隱蔽的房頂上張望草姻。 院中可真熱鬧,春花似錦稍刀、人聲如沸撩独。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,755評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)跌榔。三九已至异雁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間僧须,已是汗流浹背纲刀。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,869評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留担平,地道東北人示绊。 一個(gè)月前我還...
    沈念sama閱讀 49,378評(píng)論 3 379
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像暂论,于是被迫代替她去往敵國(guó)和親面褐。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,937評(píng)論 2 361

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

  • Node.js是目前非橙√ィ火熱的技術(shù)展哭,但是它的誕生經(jīng)歷卻很奇特。 眾所周知闻蛀,在Netscape設(shè)計(jì)出JavaScri...
    w_zhuan閱讀 3,617評(píng)論 2 41
  • topics: 1.The Node.js philosophy 2.The reactor pattern 3....
    宮若石閱讀 1,092評(píng)論 0 1
  • 個(gè)人入門學(xué)習(xí)用筆記匪傍、不過(guò)多作為參考依據(jù)。如有錯(cuò)誤歡迎斧正 目錄 簡(jiǎn)書好像不支持錨點(diǎn)觉痛、復(fù)制搜索(反正也是寫給我自己看...
    kirito_song閱讀 2,479評(píng)論 1 37
  • 模塊 Node 有簡(jiǎn)單的模塊加載系統(tǒng)役衡。在 Node 里,文件和模塊是一一對(duì)應(yīng)的薪棒。下面例子里手蝎,foo.js加載同一個(gè)...
    保川閱讀 600評(píng)論 0 0
  • 輕合上書頁(yè),眼前變得模糊俐芯,一場(chǎng)戲場(chǎng)悄然上演棵介,漢朝荒廢,董卓叛變吧史,四方豪杰聯(lián)軍鞍时。大耳劉備忠賢似渴。桃園三兄弟至死之交...
    做一只有意思的夢(mèng)閱讀 343評(píng)論 0 0