我們做東西不可能把所有的功能都放在一起,那樣會相互影響,我們需要把他們分門別類,
成都創(chuàng)新互聯(lián)公司IDC提供業(yè)務(wù):西部信息中心,成都服務(wù)器租用,西部信息中心,重慶服務(wù)器租用等四川省內(nèi)主機(jī)托管與主機(jī)租用業(yè)務(wù);數(shù)據(jù)中心含:雙線機(jī)房,BGP機(jī)房,電信機(jī)房,移動機(jī)房,聯(lián)通機(jī)房。
讓他們各自執(zhí)行各自的功能,這就是包或者模塊,包和模塊這兩個概念經(jīng)常地會用,其實(shí)他倆講的是一個東西
而在node.js中一個文件就是一個包
下面我們就來具體的講解一下:
Node.js 提供了 exports 和 require 兩個對
象,其中 exports 是模塊公開的接口,require 用于從外部獲取一個模塊的接口,即所獲
取模塊的 exports 對象。
讓我們以一個例子來了解模塊。
創(chuàng)建一個module.js的文件,內(nèi)容如下
var name; function setName(thyName){ name = thyName; }; function sayHello(){ console.log('Hello ' + name); }; //導(dǎo)出模塊 exports.setName = setName; exports.sayHello = sayHello; 再創(chuàng)建一個文件getmodule.js //獲取模塊 require('./文件名'),不需要后綴 var myModule = require('./module'); myModule.setName('MyDuoEr'); myModule.sayHello();
運(yùn)行命令
這個例子有點(diǎn)類似于創(chuàng)建一個對象,但實(shí)際上和對象又有本質(zhì)的區(qū)別,因?yàn)?br />require 不會重復(fù)加載模塊,也就是說無論調(diào)用多少次 require,獲得的模塊都是同一個。
我們在 getmodule.js 的基礎(chǔ)上稍作修改:
//獲取模塊 var hello1 = require('./module'); hello1.setName('MyDuoEr'); var hello2 = require('./module'); hello2.setName('MyDuoEr 2'); hello1.sayHello();
運(yùn)行命令
運(yùn)行后發(fā)現(xiàn)輸出結(jié)果是 Hello MyDuoEr 2,這是因?yàn)樽兞?hello1 和 hello2 指向的是
同一個實(shí)例,因此 hello1.setName 的結(jié)果被 hello2.setName 覆蓋,最終輸出結(jié)果是
由后者決定的。
覆蓋 exports
有時候我們只是想把一個對象封裝到模塊中,例如:
function Hello() { var name; this.setName = function (thyName) { name = thyName; }; this.sayHello = function () { console.log('Hello ' + name); }; };
exports.Hello = Hello;
此時我們在其他文件中需要通過 require('./singleobject').Hello 來獲取
Hello 對象,這略顯冗余,可以用下面方法稍微簡化:
function Hello() { var name; this.setName = function(thyName) { name = thyName; }; this.sayHello = function() { console.log('Hello ' + name); }; }; module.exports = Hello;
這樣就可以直接獲得這個對象了:
var Hello = require('./hello'); hello = new Hello(); hello.setName('MyDuoEr'); hello.sayHello();
注意,模塊接口的唯一變化是使用 module.exports = Hello 代替了 exports.Hello=
Hello。
標(biāo)題名稱:(三)、node.js的模塊和包
網(wǎng)頁URL:http://aaarwkj.com/article24/gojjje.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化、企業(yè)網(wǎng)站制作、網(wǎng)站策劃、品牌網(wǎng)站設(shè)計(jì)、外貿(mào)建站、網(wǎng)站設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)