您好,登錄后才能下訂單哦!
在寫 Node.js 應用程序的時候,你確實可以把所有代碼放在巨大原 index.js 文件中,不在乎你的應用程序會變得多大多復雜。Node.js 解釋器不會在意這個事情。但在代碼組織方面,你很快就會陷入混亂,不能理解代碼,而且難以調試。所以,作為一個人,你應該關心代碼的結構。這就是使用模塊的原因。
你可以把 Node.js 模塊當作 JavaScript 庫 —— 是整體代碼中你想放在一起的某個部分(比如,函數(shù)集),你會想把這部分代碼相對獨立于代碼庫中的其它部分,可以把事情區(qū)分清楚。
就們我們把襪子放在衣柜一個抽屜,把襯衣放在衣柜的另一個抽屜 —— 我們可以把它們組成一天的著裝 ——在代碼庫中,我們將不同的部分保存在不同的模塊中,然后將它們有條不紊地合并成一個應用程序。
內建模塊
即使我們不創(chuàng)造任何 Node.js 模塊,也有模塊可用,因為 Node.js 環(huán)境提供了內建模塊。我們已經(jīng)遇到過一個模塊,就是在博客中尋找如何使用內建的 SHATWG URL 解析器的時候。
在我們自己的代碼文件中,我們需要使用已經(jīng)存在但是在別處聲明的代碼 —— 這種情況下,URL類是 Node.js 內置模塊url中的一部分。
var URL = require('url').URL;
require('url')讓我們可以訪問url模塊。這個模塊定義在哪里,是怎么定義的,對我們來說完全不透明 —— 我們所需要知道的只是它的名稱 ——url—— 以及它公開的屬性,比如URL。
其它內建的模塊直接導出我們需要的屬性(通常是 JavaScript 對象)。以http模塊為例:
var http = require('http'); http.createServer(function (req, res) { res.writeHead(200, {'Content-Type': 'text/html'}); res.end('Hello World!'); }).listen(8080);
這里,請求http模塊讓我們可以直接訪問http對象,我們可以直接使用其方法,比如createServer。
Node 初學者這本書講述了如何使用 Node.js 寫一個完整的 Web 服務器,它就是使用的內建http模塊。
外部模塊
內建模塊隨 Node.js 發(fā)布,它可以解決很多開發(fā)問題,而不需要為每個應用發(fā)明新的輪子,但是真正促進 Node.js 編程能力的是由來自 Node.js 社區(qū)的開源模塊構建起來的龐大生態(tài)系統(tǒng)。這些模塊也可以集成到我們的代碼庫中,但是由于它們不是內置的,并且不會隨每次安裝Node.js 一起安裝,所以只在是我們的代碼中require是不夠的。我們需要先安裝包含外部模塊的代碼庫,由于 NPM,Node Package Manager(Node 包管理器) 的存在,這很容易。
請參博客文章,它以如何使用 async 庫為例來介紹如何使用外部模塊。
此外,Node工匠書還使用了一個章節(jié)來介紹了使用 NPM 的細節(jié)。
創(chuàng)建你自己的模塊
內建模塊和外部模塊都是別人提供的,但它們不會妨礙你創(chuàng)建自己的 Node.js 模塊。
下面的例子創(chuàng)建了一個名為myRandom的模塊,它會提供了一個輔助函數(shù),用于返回 0 到 10 之間的數(shù)。
文件myRandom.js:
function getRandom(min, max) { return Math.random() * (max - min) + min; } exports.between1and10 = function() { return getRandom(1, 10); };
你應該把代碼放在自己的myRandom.js文件中。由于此文件存在,并通過exports向外提供屬性,另一個文件index.js可以使用導出的功能:
文件index.js:
var myRandom = require('./myRandom.js'); console.log(myRandom.between1and10());
require再次發(fā)揮作用,它讓本地myRandom模塊中導出的屬性生效 —— 在這里是指between1and10函數(shù)。
注意:雖然模塊系統(tǒng)允許公開模塊的功能,但它也允許隱藏在模塊之外不會用到的功能,只要不通過exports導出就好。即使index.js文件請求了myRandom.js文件,它也不能訪問未導出的getRandom函數(shù):
var myRandom = require('./myRandom.js'); console.log(myRandom.getRandom(5, 99));
這會導致 TypeError: myRandom.getRandom is not a function.
通過將實現(xiàn)細節(jié)隱藏在模塊中,只暴露出需要在其它代碼中使用的部分,可以很好的組織你的代碼。
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。