NodeJS

簡單的說 Node.js 就是運行在服務(wù)端的 JavaScript。


Node.js模塊系統(tǒng)

為了讓Node.js的文件可以相互調(diào)用锦募,Node.js提供了一個簡單的模塊系統(tǒng)摆屯。
模塊是Node.js 應(yīng)用程序的基本組成部分,文件和模塊是一一對應(yīng)的糠亩。換言之虐骑,一個 Node.js 文件就是一個模塊,這個文件可能是JavaScript 代碼赎线、JSON 或者編譯過的C/C++ 擴展廷没。

引入模塊

在 Node.js 中狭归,引入一個模塊非常簡單亡鼠,如下我們創(chuàng)建一個 main.js 文件并引入 hello 模塊根盒,代碼如下:

var hello = require('./hello');
hello.world();

以上實例中森瘪,代碼 require('./hello') 引入了當(dāng)前目錄下的 hello.js 文件(./ 為當(dāng)前目錄,node.js 默認后綴為 js)粪躬。

Node.js 提供了 exports 和 require 兩個對象,其中 exports 是模塊公開的接口扇雕,require 用于從外部獲取一個模塊的接口,即所獲取模塊的 exports 對象凑兰。

接下來我們就來創(chuàng)建 hello.js 文件祟剔,代碼如下:

exports.world = function() {
  console.log('Hello World');
}

在以上示例中组力,hello.js 通過 exports 對象把 world 作為模塊的訪問接口蛉鹿,在 main.js 中通過 require('./hello') 加載這個模塊,然后就可以直接訪 問 hello.js 中 exports 對象的成員函數(shù)了职抡。

有時候我們只是想把一個對象封裝到模塊中瞧筛,格式如下:

module.exports = function() {
  // ...
}

例如:

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

這樣就可以直接獲得這個對象了:

//main.js 
var Hello = require('./hello'); 
hello = new Hello(); 
hello.setName('BYVoid'); 
hello.sayHello(); 

模塊接口的唯一變化是使用 module.exports = Hello 代替了exports.world = function(){}衷恭。
在外部引用該模塊時,其接口對象就是要輸出的 Hello 對象本身,而不是原先的 exports。


服務(wù)端的模塊放在哪里

使用模塊的方式:

var http = require("http");
...
http.createServer(...);

Node.js 中自帶了一個叫做 http 的模塊伍茄,我們在我們的代碼中請求它并把返回值賦給一個本地變量。

這把我們的本地變量變成了一個擁有所有 http 模塊所提供的公共方法的對象照捡。

Node.js 的 require 方法中的文件查找策略如下:

由于 Node.js 中存在 4 類模塊(原生模塊和3種文件模塊)颅湘,盡管 require 方法極其簡單,但是內(nèi)部的加載卻是十分復(fù)雜的栗精,其加載優(yōu)先級也各自不同闯参。如下圖所示:


require

從文件模塊緩存中加載

盡管原生模塊與文件模塊的優(yōu)先級不同,但是都會優(yōu)先從文件模塊的緩存中加載已經(jīng)存在的模塊悲立。

從原生模塊加載

原生模塊的優(yōu)先級僅次于文件模塊緩存的優(yōu)先級鹿寨。require 方法在解析文件名之后,優(yōu)先檢查模塊是否在原生模塊列表中薪夕。以http模塊為例脚草,盡管在目錄下存在一個 http/http.js/http.node/http.json 文件,require("http") 都不會從這些文件中加載寥殖,而是從原生模塊中加載玩讳。
原生模塊也有一個緩存區(qū)涩蜘,同樣也是優(yōu)先從緩存區(qū)加載嚼贡。如果緩存區(qū)沒有被加載過,則調(diào)用原生模塊的加載方式進行加載和執(zhí)行同诫。

從文件加載

當(dāng)文件模塊緩存中不存在粤策,而且不是原生模塊的時候,Node.js 會解析 require 方法傳入的參數(shù)误窖,并從文件系統(tǒng)中加載實際的文件叮盘,加載過程中的包裝和編譯細節(jié)在前一節(jié)中已經(jīng)介紹過秩贰,這里我們將詳細描述查找文件模塊的過程,其中柔吼,也有一些細節(jié)值得知曉毒费。

require方法接受以下幾種參數(shù)的傳遞:
  • http、fs愈魏、path等觅玻,原生模塊。
  • ./mod或../mod培漏,相對路徑的文件模塊溪厘。
  • /pathtomodule/mod,絕對路徑的文件模塊牌柄。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末畸悬,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子珊佣,更是在濱河造成了極大的恐慌蹋宦,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件咒锻,死亡現(xiàn)場離奇詭異妆档,居然都是意外死亡,警方通過查閱死者的電腦和手機虫碉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進店門贾惦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人敦捧,你說我怎么就攤上這事须板。” “怎么了兢卵?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵习瑰,是天一觀的道長。 經(jīng)常有香客問我秽荤,道長甜奄,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任窃款,我火速辦了婚禮课兄,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘晨继。我一直安慰自己烟阐,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蜒茄,像睡著了一般唉擂。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上檀葛,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天玩祟,我揣著相機與錄音,去河邊找鬼屿聋。 笑死卵凑,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的胜臊。 我是一名探鬼主播勺卢,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼象对!你這毒婦竟也來了黑忱?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤勒魔,失蹤者是張志新(化名)和其女友劉穎甫煞,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體冠绢,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡抚吠,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了弟胀。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片楷力。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖孵户,靈堂內(nèi)的尸體忽然破棺而出萧朝,到底是詐尸還是另有隱情,我是刑警寧澤夏哭,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布检柬,位于F島的核電站,受9級特大地震影響竖配,放射性物質(zhì)發(fā)生泄漏何址。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一进胯、第九天 我趴在偏房一處隱蔽的房頂上張望用爪。 院中可真熱鬧,春花似錦龄减、人聲如沸项钮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽羞延。三九已至入愧,卻和暖如春巩步,著一層夾襖步出監(jiān)牢的瞬間终畅,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工赠涮, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留炸裆,地道東北人洛史。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像捆毫,于是被迫代替她去往敵國和親损合。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,713評論 2 354

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

  • 創(chuàng)建模塊 在 Node.js 中厂僧,創(chuàng)建一個模塊非常簡單,如下我們創(chuàng)建一個main.js文件,代碼如下: varhe...
    大詩兄_zl閱讀 209評論 0 0
  • 1 命令行窗口 1.1. 命令行窗口(小黑屏)餐济、CMD窗口、終端韵吨、shell 開始菜單 -> 運行 -> cmd ...
    錦衣夜行001閱讀 1,617評論 0 1
  • 前言 js是從網(wǎng)頁小腳本演變過來的椿疗,至今,前端的js庫糠悼,也不像一個真正的模塊届榄。前端js經(jīng)歷了工具類庫、組件庫倔喂、前端...
    白昔月閱讀 3,278評論 2 11
  • 本文主要源自https://github.com/jimuyouyou/node-interview-questi...
    十里江城閱讀 2,464評論 0 9
  • 一铝条、Node快速體驗 1、 Node介紹 (1) Node.js是什么 Node 是一個基于Chrome V8 ...
    寵辱不驚丶歲月靜好閱讀 3,307評論 0 6