在Node.js中,以模塊為單位劃分所有的功能,并且提供了一個完整的模塊加載機制,所以我們可以將應(yīng)用程序劃分為各個不同的部分,并且對這些部分進行很好的協(xié)同管理。通過將各種可重用代碼編寫在各種模塊中的方法,可以大大減少應(yīng)用程序的代碼量,提高應(yīng)用程序的開發(fā)效率以及應(yīng)用程序代碼的可讀性。通過模塊加載機制,可以將各種第三方模塊引入到我們的應(yīng)用程序中。
創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的渝中網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
在node.js中,提供npm包管理工具,用于從第三方網(wǎng)站上下載各種Node.js包。
一、模塊
1.1 加載模塊
在Node.js中,以模塊為單位劃分所有的功能,一個Node.js應(yīng)用程序由大量的模塊組成,每一個模塊都是一個JavaScript文件,在加載node.js中預(yù)先定義的核心模塊,我們只需要require('模塊名'),例如require('http'),在將第三方類庫引入到我們的應(yīng)用程序時,需要指定該文件的完整路徑及文件名,例如 require('./script/foo.js')
1.2 訪問模塊
1.2.1使用exports對象訪問
在一個模塊文件中定義變量、函數(shù)或?qū)ο笾辉谠撃K內(nèi)有效,當(dāng)你需要從外部模塊引用這些變量、函數(shù)或?qū)ο髸r,需要再改模塊內(nèi),例如,建一個testModule.js,代碼如下:
var testVar = "Can you see me now ? "; var funName = function(name){ console.log('My name is' + name); } exports.testVar = testVar ; exports.funName = funName ;
那么我們想在http.js中使用這些變量、函數(shù)或?qū)ο?,可在http.js中書寫如下代碼:
var test1 = require('./testModule.js'); // 通過test1訪問testModule.js模塊內(nèi)的testVar變量 和funName函數(shù) console.log(test1.testVar) test1.funName('Luckfine')
node 運行下這個http.js node http.js
運行結(jié)果如下
1.2.2使用module.exports對象訪問
當(dāng)你需要從外部模塊引用這些變量、函數(shù)或?qū)ο髸r,使用exports對象,也可以使用module.exports,但是需要將模塊定義一個類時,只能用module.exports。
例如定義一個testModule類,在testModule.js中如下代碼:
var _name,_age var name = '',age = 0; var foo = function(name,age){ _name = name ; _age = age ; } // 獲取私有變量_name的變量只 foo.prototype.GetName = function(name){ return _name; }; // 設(shè)置私有變量_name的變量值 foo.prototype.SetName = function(name){ _name = name; } // 獲取私有變量_age的變量只 foo.prototype.GetAge = function(age){ return _age; }; // 設(shè)置私有變量_name的變量值 foo.prototype.SetAge = function(age){ _age = age; } foo.prototype.name = name; foo.prototype.age = age; module.exports = foo;
那么我們想在http.js中使用這個類的變量、函數(shù)或?qū)ο?,可在http.js中書寫如下代碼:
var foo = require('./testModule.js'); var myFoo = new foo('Luckfine',18); console.log('獲取修改前的私有變量值') console.log(myFoo.GetName()); console.log(myFoo.GetAge()); console.log('修改私有變量'); myFoo.SetName('Baby'); myFoo.SetAge(16); console.log('獲取修改后的私有變量值') console.log(myFoo.GetName()); console.log(myFoo.GetAge()); console.log('獲取修改前的公有變量值') console.log(myFoo.name); console.log(myFoo.age); console.log('修改公有變量') myFoo.name = "Tom"; myFoo.age = 20; console.log('獲取修改后的公有變量值') console.log(myFoo.name); console.log(myFoo.age);
然后在iTerm中運行node http.js命令,運行結(jié)果如下所示
總結(jié)以上:
也就是說,js文件和js文件之間有兩種合作的模式:
1) 某一個js文件中,提供了函數(shù),供別人使用。 只需要暴露函數(shù)就行了; exports.msg=msg;
2) 某一個js文件,描述了一個類。 module.exports = People;
二、npm包管理
npm是跟隨Node.js一起的包管理工具,能解決Node.js代碼部署上的很多問題,當(dāng)我們使用npm去安裝一些第三方庫的時候,安裝包會放在運行npm命令時所在的目錄中的node_modules文件夾中,如果當(dāng)前目錄下沒有node_modules,會在當(dāng)前目錄下生成node_modules目錄,并把我們需要的第三方庫放在node_modules中。
所以在安裝的時候,要注意,命令提示符所在的位置。
安裝第三方庫的命令 npm install 模塊名字, 假如我們需要安裝express,那么只需要在命令行中輸入npm install express
1.我們的依賴包,可能在隨時更新,我們永遠(yuǎn)想保持更新,或者某持某一個版本;
2.項目越來越大的時候,給別人看的時候,沒有必要再次共享我們引用的第三方模塊。
所以我們可以使用package.json來管理依賴包。
在cmd中,使用npm init可以初始化一個package.json文件,用回答問題的方式生成一個新的package.json文件。
生成package.json的作用就是,如果一不小心我們丟了什么依賴,那么只要我們直接npm install就可以安裝package.json中的缺失的依賴;
package.json中版本號前面有一個尖角號,表示固定版本,即固定使用我現(xiàn)在安裝的版本;
例如我們現(xiàn)在新建一個文件夾
1、新建文件夾
我們現(xiàn)在需要安裝一個第三方庫express,就先進入這個文件夾,打開命令行,在此輸入 npm install express'' 等命令行完成之后,我們會看到在文件夾中就新建了一個node_modules文件夾,并且把我們需要的庫已經(jīng)安裝在文件夾中
2、安裝后文件夾中內(nèi)容
然后我們需要一個package.json管理我們的包,就可以在命令行中輸入npm init,這時可已根據(jù)命令行的提示回答問題建立package.json
3、建立package.json
那么我們這個項目的一些依賴,版本號,描述,作者等都可以通過package.json進行相應(yīng)管理。
4、包管理
我這個包管理內(nèi)容比較少,那么正常情況下package.jaon都有如下內(nèi)容
三、模塊對象的屬性
這個作為更深入的了解。
在模塊文件內(nèi)部,可以訪問當(dāng)前模塊的如下一些屬性。
module.id : 表示該模塊文件的絕對路徑。
module.filename :屬性值為當(dāng)前模塊的文件名
module.loaded :屬性值為布爾值,當(dāng)屬性值為false時表示模塊尚未加載完畢,反之為加載完畢。
module.parent:屬性值為當(dāng)前模塊的父模塊對象,即調(diào)用當(dāng)前模塊的模塊對象
module.children:屬性值為一個數(shù)組,其中存放了當(dāng)前模塊所有子模塊對象,即當(dāng)前模塊中已加載的所有模塊對象。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。