Node中module.exports和exports之间的区别

在Node环境中,一个模块中输出变量的方式有两种,分别是:

1.module.exports

// module.js

function hello(name) {
    console.log('Hello, ' + name + '!');
}

module.exports = hello;

2.exports

// module.js

function hello(name) {
    console.log('Hello, ' + name + '!');
}
exports.hello = hello;

以上两种写法上都是正确的,那么这两写法有什么区别呢?接着我们看一看Node的加载机制;

首先,Node会把整个待加载的module.js文件放入一个包装函数load中执行。在执行这个load()函数前,Node准备好了module变量:

var module = {
    id: 'module',
    exports: {}
};

load()函数最终返回module.exports

var load = function (exports, module) {
    // module.js的文件内容
    ...
    // load函数返回:
    return module.exports;
};

var exported = load(module.exports, module);

默认情况下,Node准备的exports变量和module.exports变量实际上是同一个变量,并且初始化为空对象,我们可以把要输出的东西直接假期在这个空对象里面;但是,如果我们要输出的是一个函数或数组,那么,只能给module.exports赋值,给exports赋值是无效的,因为赋值后,module.exports仍然是空对象。

因此,我们得出以下结论:

如果要输出一个键值对象{},可以利用exports这个已存在的空对象{},并继续在上面添加新的键值;

如果要输出一个函数或数组,必须直接对module.exports对象赋值。

直接对module.exports赋值,可以应对任何情况;

我们强烈建议使用module.exports = xxx的方式来输出模块变量,这样只需要记忆一种方法。

更详细的讲解可以移步廖雪峰老师的博客

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值