日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

exports与module.exports的区别

發(fā)布時(shí)間:2025/4/14 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 exports与module.exports的区别 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

原文:http://www.hacksparrow.com/node-js-exports-vs-module-exports.html

你肯定非常熟悉nodejs模塊中的exports對象,你可以用它創(chuàng)建你的模塊。例如:(假設(shè)這是rocker.js文件)

exports.name = function() {console.log('My name is Lemmy Kilmister'); };

在另一個(gè)文件中你這樣引用

var rocker = require('./rocker.js'); rocker.name(); // 'My name is Lemmy Kilmister'

那到底Module.exports是什么呢?它是否合法呢?

其實(shí),Module.exports才是真正的接口,exports只不過是它的一個(gè)輔助工具。 最終返回給調(diào)用的是Module.exports而不是exports。

所有的exports收集到的屬性和方法,都賦值給了Module.exports。當(dāng)然,這有個(gè)前提,就是Module.exports本身不具備任何屬性和方法。如果,Module.exports已經(jīng)具備一些屬性和方法,那么exports收集來的信息將被忽略。

修改rocker.js如下:

module.exports = 'ROCK IT!'; exports.name = function() {console.log('My name is Lemmy Kilmister'); };

?再次引用執(zhí)行rocker.js

var rocker = require('./rocker.js'); rocker.name(); // TypeError: Object ROCK IT! has no method 'name'

發(fā)現(xiàn)報(bào)錯(cuò):對象“ROCK IT!”沒有name方法

rocker模塊忽略了exports收集的name方法,返回了一個(gè)字符串“ROCK IT!”。由此可知,你的模塊并不一定非得返回“實(shí)例化對象”。你的模塊可以是任何合法的javascript對象--boolean, number, date, JSON, string, function, array等等。

你的模塊可以是任何你設(shè)置給它的東西。如果你沒有顯式的給Module.exports設(shè)置任何屬性和方法,那么你的模塊就是exports設(shè)置給Module.exports的屬性。

下面例子中,你的模塊是一個(gè)類:

module.exports = function(name, age) {this.name = name;this.age = age;this.about = function() {console.log(this.name +' is '+ this.age +' years old');}; };

可以這樣應(yīng)用它:

var Rocker = require('./rocker.js'); var r = new Rocker('Ozzy', 62); r.about(); // Ozzy is 62 years old

下面例子中,你的模塊是一個(gè)數(shù)組:

module.exports = ['Lemmy Kilmister', 'Ozzy Osbourne', 'Ronnie James Dio', 'Steven Tyler', 'Mick Jagger'];

可以這樣應(yīng)用它:

var rocker = require('./rocker.js'); console.log('Rockin in heaven: ' + rocker[2]); //Rockin in heaven: Ronnie James Dio

現(xiàn)在你明白了,如果你想你的模塊是一個(gè)特定的類型就用Module.exports。如果你想的模塊是一個(gè)典型的“實(shí)例化對象”就用exports

給Module.exports添加屬性類似于給exports添加屬性。例如:

module.exports.name = function() {console.log('My name is Lemmy Kilmister'); };

同樣,exports是這樣的

exports.name = function() {console.log('My name is Lemmy Kilmister'); };

請注意,這兩種結(jié)果并不想同。前面已經(jīng)提到module.exports是真正的接口,exports只不過是它的輔助工具。推薦使用exports導(dǎo)出,除非你打算從原來的“實(shí)例化對象”改變成一個(gè)類型。

轉(zhuǎn)載于:https://www.cnblogs.com/dtdxrk/p/4742406.html

總結(jié)

以上是生活随笔為你收集整理的exports与module.exports的区别的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。