关于node里面的module.exports和exports的异同,网上已经有很多的资料,很多的文章,很多的博客,看了很多,好像懂了,又好像不懂,过几天又不懂了...大致总结是这样的:
//下面这种情况下是一致的:
exports.foo=123 //可以是字符串,数字,数组或函数,都无所谓
module.exports.foo=123 //可以是字符串,数字,数组或函数,都无所谓 //下面这种情况下是不一致的:
module.exports = 123 //可以是字符串,数字,数组或函数,都无所谓
exports = 123 //可以是字符串,数字,数组或函数,都无所谓
至于为什么会这样,我一直都不太清楚,直到看到下面这段代码:
var module = {
exports: {
}
}; (function(module,exports){
module.exports = 123; //可以修改module对象下的exports属性
exports = 123; //修改的是当前函数环境里的exports变量,而非module.exports
exports.foo = 123 //可以修改module.exports下的foo属性 })(module,module.exports);
这个函数里的参数module和exports就对应了nodejs里的module和exports,module和module.exports都作为参数被传递给了函数,所以,当我们修改参数的属性的时候,它对于参数指向的这个对象是有效的,而直接修改这个参数,只是在函数环境里修改这个变量,对象并没有被修改.
这就解释了为什么可以直接给module.exports赋值,却不能给exports直接赋值.也解释了为什么module.exports.foo和exports.foo是完全一样的.
好了,整个世界都清净了~~~