站長資訊網
        最全最豐富的資訊網站

        nodejs模塊是什么

        模塊是Node.js應用程序的基本組成部分,文件和模塊是一一對應的,一個Nodejs模塊就是一個文件,而這個文件可能是JavaScript代碼、JSON或者編譯過的“C/C++”擴展,引用模塊可用“require('文件路徑')”語句。

        nodejs模塊是什么

        本教程操作環境:windows7系統、nodejs 12.19.0版、Dell G3電腦。

        為了讓Node.js的文件可以相互調用,Node.js提供了一個簡單的模塊系統。

        模塊是Node.js 應用程序的基本組成部分,文件和模塊是一一對應的。換言之,一個 Node.js 文件就是一個模塊,這個文件可能是JavaScript 代碼、JSON 或者編譯過的C/C++ 擴展。

        對于nodejs來說,一個文件就是一個模塊,你可以export接口出去,也可以require別的模塊進來。

        // module1.js exports.func1 = function(){         console.log('func1 from module1 called'); }

        module1把函數func1通過exports對象作為模塊的公共訪問接口。

        //module2.js var in_module1 = require('./module1.js'); in_module1.func1(); exports.func2 = function(){         console.log('func2 from module2 called'); }

        module2把module1 require進來,這個時候,in_module1就相當于module1的exports對象。當使用in_module1調用func1的時候,相當于通過module1的exports對象調用func1。

        同時,module2自己的函數func2也通過模塊的exports對象作為module2公共接口。

        // module3.js var in_module2 = require('./module2.js'); in_module2.func2();

        同理,module3把module2 require進來,此時in_module2就相當于module2的exports對象。

        運行結果如下:

        rlan@rlan-LA:~/nodejs/nodetest$ node module2.js func1 from module1 called rlan@rlan-LA:~/nodejs/nodetest$ node module3.js func1 from module1 called func2 from module2 called

        nodejs引入模塊不僅僅得到模塊的公共接口,同時會把文件里別的語句一并引用進來,比如:

        module1.js改為

        // module2.js console.log('this is in module2'); var in_module1 = require('./module1.js');    in_module1.func1();    exports.func2 = function(){        console.log('func2 from module2 called'); }

        module2引入了module1的func1函數,同時執行了module1中的打印語句:

        rlan@rlan-LA:~/nodejs/nodetest$ node module1.js this is in module1 rlan@rlan-LA:~/nodejs/nodetest$ node module2.js this is in module2         - module2 self this is in module1         - require module1 func1 from module1 called  - module2 self

        現在,module2 載入了module1,module3載入了module2,如果module3再載入一次module1會怎么樣呢?

        // module3.js var in_module1 = require('./module1.js'); var in_module2 = require('./module2.js');  in_module1.func1(); in_module2.func2();

        這時候,module3首先載入了module1,又載入了module2,module2自己又載入了module1的部分,運行結果為

        rlan@rlan-LA:~/nodejs/nodetest$ node module3.js this is in module1        -  require module1 this is in module2        -  require module2 func1 from module1 called -  require module2 func1 from module1 called -  module3 self func2 from module2 called -  module3 self

        假如把module3的require順序調整一下:

        // module3.js var in_module2 = require('./module2.js'); var in_module1 = require('./module1.js');  in_module1.func1(); in_module2.func2();

        運行結果為:

        rlan@rlan-LA:~/nodejs/nodetest$ node module3.js this is in module2         - require module2 this is in module1         - require module2 func1 from module1 called  - require module2 func1 from module1 called  - module3 self func2 from module2 called  - module3 self

        看起來nodejs用某種機制保證了同一個模塊在另一個模塊里不會被重復載入,所以

        this is in module1

        這一行只出現了一次,雖然在module3.js里似乎被載入了兩次。

        那么,如果循環載入了會發生什么呢?現在我們讓module1來require module2:

        // module1.js console.log('this is in module1');  var in_module2 = require('./module2.js');  exports.func1 = function(){         console.log('func1 from module1 called'); }
        // module2.js console.log('this is in module2'); var in_module1 = require('./module1.js');  in_module1.func1();  exports.func2 = function(){         console.log('func2 from module2 called'); }

        運行結果如下:

        rlan@rlan-LA:~/nodejs/nodetest$ node module1.js this is in module1 this is in module2 /home/rlan/nodejs/nodetest/module2.js:4 in_module1.func1();            ^ TypeError: in_module1.func1 is not a function     at Object.<anonymous> (/home/rlan/nodejs/nodetest/module2.js:4:12)     at Module._compile (module.js:410:26)     at Object.Module._extensions..js (module.js:417:10)     at Module.load (module.js:344:32)     at Function.Module._load (module.js:301:12)     at Module.require (module.js:354:17)     at require (internal/module.js:12:17)     at Object.<anonymous> (/home/rlan/nodejs/nodetest/module1.js:3:18)     at Module._compile (module.js:410:26)     at Object.Module._extensions..js (module.js:417:10) rlan@rlan-LA:~/nodejs/nodetest$ node module2.js this is in module2 this is in module1 func1 from module1 called

        nodejs似乎阻止了載入自己的行為,運行module2的時候,行為跟module1沒有載入module2的結果一樣,并沒有報錯。而在運行module1的時候,當走到module2里面,忽略了require module1的語句之后,module2調用了module1的func1,程序出錯。

        綜上,nodejs里嵌套重復載入模塊(或者載入自己)的require語句是不能正確執行的。

        【推薦學習:《nodejs 教程》】

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 亚洲国产精品日韩| 精品欧洲av无码一区二区三区| 精品久久久噜噜噜久久久| 亚洲AV午夜福利精品一区二区| 亚洲精品和日本精品| 无码人妻精品一区二区三区99仓本| 永久无码精品三区在线4| 久久亚洲精精品中文字幕| A级精品国产片在线观看| 99久久成人国产精品免费| 无码精品一区二区三区免费视频| 高清日韩精品一区二区三区| 国产精品偷伦视频免费观看了 | 久久se精品一区二区影院 | 久久精品一区二区三区不卡| 欧美日韩国产精品系列| 国产精品内射后入合集| 91无码人妻精品一区二区三区L | 国产一区精品| 国精品午夜福利视频不卡| 欧洲精品视频在线观看| 欧美日韩精品| 久久99热狠狠色精品一区| 无码国内精品久久人妻麻豆按摩| 国产精品后入内射日本在线观看| 精品国产日韩亚洲一区| 2018国产精华国产精品| 免费精品精品国产欧美在线欧美高清免费一级在线 | 婷婷国产成人精品一区二| 久久91精品久久91综合| 亚洲精品国产美女久久久| 国产精品v欧美精品v日本精| 国产精品福利在线播放| 亚洲国产精品自在拍在线播放| 91精品国产福利在线观看麻豆| 99在线精品视频| 久久99精品国产| 精品国产AV一区二区三区| 亚洲欧美激情精品一区二区| 免费精品国自产拍在线播放| 麻豆精品三级全部视频 |