zoukankan      html  css  js  c++  java
  • nodejs里的module.exports和exports的关系

    关于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);

    这个函数里的参数moduleexports就对应了nodejs里的moduleexports,modulemodule.exports都作为参数被传递给了函数,所以,当我们修改参数的属性的时候,它对于参数指向的这个对象是有效的,而直接修改这个参数,只是在函数环境里修改这个变量,对象并没有被修改.

    这就解释了为什么可以直接给module.exports赋值,却不能给exports直接赋值.也解释了为什么module.exports.foo和exports.foo是完全一样的.

    好了,整个世界都清净了~~~

  • 相关阅读:
    一、left
    padding溢出
    一、
    Python创建、删除桌面、启动组快捷方式的例子分享
    openstack常见问题解决方法总结
    __attribute__ 详解
    __ATTRIBUTE__ 知多少?
    CentOS如何设置终端显示字符界面区域的大小
    shell使用技巧
    openstack 安全策略权限控制等api接口
  • 原文地址:https://www.cnblogs.com/liulangmao/p/4901665.html
Copyright © 2011-2022 走看看