您的位置:首页 > Web前端 > Node.js

node.js 中exports和module.exports的区别

2018-01-06 23:21 645 查看
1.先参考:
http://cnodejs.org/topic/5231a630101e574521e45ef8
require 用来加载代码,而 exports 和 module.exports 则用来导出代码。但很多新手可能会迷惑于 exports 和 module.exports 的区别,为了更好的理解 exports 和 module.exports 的关系,我们先来巩固下 js 的基础。示例:

test.js

var a = {name: 1};var b = a;

console.log(a);console.log(b);

b.name = 2;console.log(a);console.log(b);

var b = {name: 3};console.log(a);console.log(b);

运行 test.js 结果为:

{ name: 1 }{ name: 1 }{ name: 2 }{ name: 2 }{ name: 2 }{ name: 3 }

解释:a 是一个对象,b 是对 a 的引用,即 a 和 b 指向同一块内存,所以前两个输出一样。当对 b 作修改时,即 a 和 b 指向同一块内存地址的内容发生了改变,所以 a 也会体现出来,所以第三四个输出一样。当 b 被覆盖时,b 指向了一块新的内存,a 还是指向原来的内存,所以最后两个输出不一样。

明白了上述例子后,我们只需知道三点就知道 exports 和 module.exports 的区别了:
module.exports 初始值为一个空对象 {}
exports 是指向的 module.exports 的引用
require() 返回的是 module.exports 而不是 exports

现在我们来看 Node.js 官方文档的截图:

我们经常看到这样的写法:
exports = module.exports = somethings


上面的代码等价于:
module.exports = somethings
exports = module.exports


原理很简单,即 module.exports 指向新的对象时,exports 断开了与 module.exports 的引用,那么通过 exports = module.exports 让 exports 重新指向 module.exports 即可。

2.再参考,应该能理解透了:https://www.2cto.com/kf/201412/360211.html

在写node.js代码时,我们经常需要自己写模块(module)。同时还需要在模块最后写好模块接口,声明这个模块对外暴露什么内容。实际上,node.js的模块接口有多种不同写法。这里作者对此做了个简单的总结。

返回一个JSON Object

如下代码是一个简单的示例。

1 var exp = { 

2   "version": "1.0.0", 

3   "function1": null, 

4   "module1": null,

5 };

6 module.exports = exp;

这种方式可以用于返回一些全局共享的常量或者变量,例如

1 // MATH.js

2 var MATH = {

3   "pi": 3.14,

4   "e": 2.72,

5 };



7 module.exports = MATH;

调用方式为

1 var MATH = require("./MATH")

2 console.log(MATH.pi);

这种方式还可以用于返回几个require的其他模块,可以实现一次require多个模块

1 // module_collection.js

2 var module_collection = {

3   "module1": require("./module1"),

4   "module2": require("./module2"),

5 };



7 module.exports = module_collection;

调用方式为

1 var module_collection = require("./module_collection");

2 var module1 = module_collection.module1;

3 var module2 = module_collection.module2;

4 // Do something with module1 and module2

其实这种方式还有个变种,如下,通常可以返回几个函数

 1 // functions.js

 2 var func1 = function() {

 3   console.log("func1");

 4 };

 5 

 6 var func2 = function() {

 7   console.log("func2");

 8 };

 9 

10 exports.function1 = func1;

11 exports.function2 = func2;

调用方式为

1 var functions = require("./functions");

2 functions.function1();

3 functions.function2();

返回一个构造函数,也就是一个类

如下是一个简单的示例。

 1 // CLASS.js

 2 var CLASS = function(args) {

 3   this.args = args;

 4 }

 5 

 6 CLASS.prototype.func = function() {

 7   console.log("CLASS.func");

 8   console.log(this.args);

 9 };

10 

11 module.exports = CLASS;

调用方法为

 

1 var CLASS = require("./CLASS")

2 var c = new CLASS("arguments");

返回一个普通函数

 

如下是一个简单的示例

 

复制代码

1 // func.js

2 var func = function() {

3   console.log("this is a testing function");

4 };



6 module.exports = func;

调用方法为

1 var func = require("./func");

2 func();

返回一个对象object

如下是一个简单的示例

 1 // CLASS.js

 2 var CLASS = function() {

 3   this.say_hello = "hello";

 4 };

 5 

 6 CLASS.prototype.func = function() {

 7   console.log("I say " + this.say_hello);

 8 };

 9 

10 module.exports = new CLASS();

调用方法为

1 var obj = require("./CLASS");

2 obj.func();

有时候我们需要模块返回一个单例 singleton. 可以利用上面的方式1和方式4来实现。也就是如下两种形式

1 // MATH.js

2 var MATH = {

3   "pi": 3.14,

4   "e": 2.72,

5 };



7 module.exports = MATH;

以及

 1 // CLASS.js

 2 var CLASS = function() {

 3   this.say_hello = "hello";

 4 };

 5 

 6 CLASS.prototype.func = function() {

 7   console.log("I say " + this.say_hello);

 8 };

 9 

10 module.exports = new CLASS();

最后,真的很喜欢JavaScript这个语言,很方便。而且node.js的出现极大的增强了这门语言的能力。看好它!

就上面那些内容了,很简单的,哈哈!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: