zoukankan      html  css  js  c++  java
  • node.js中的exports和module.exports

    不同的编程语言都有各自的代码组织和复用的方式,如.net、php中的命名空间,python中的import,ruby中的module等,来避免命名空间污染。一直都没搞清楚node中的exports和module.exports的区别,借此搞清楚node的代码模块复用方式。

    首先怎么创建node中的modules。

    可以直接创建一个文件作为module,如下module.js

    function writeLine(){
        console.log("module.js");
    }
    exports.dbleNum=function(num){
        return num*2;
    }
    exports.tripleNum=function(num){
        return num*3;
    }

     其中,我们exports两个函数,在example.js文件中(如下),我们可以利用require就能取得这两个函数

    var module = require('./module');
    console.log(module.dbleNum(3));
    console.log(module.tripleNum(3));

    这样就可以用module.js中的函数了。其中./表示这模块和当前的调用模块在同一目录下,若是放在子目录lib下面,就是require('./lib/module'),不需要后缀.js的。

    当然这是简单的单个文件的模块,如果是比较复杂的可以以包的形式,也即n像pm安装的包那样子。如上module.js文件,我们将其放在example_module文件夹下,里面新建一个package.json文件(这是是包的主要信息),有名称,描述,依赖,main,作者,版本等等,我们简略一下就不写那么多,主要写了如下

    {
      "name": "module",
      "description": "example",
      "version": "0.0.1",
      "dependencies": {
        },
      "main": "module",
      }

     一般模块中的主文件是index.js,也就是"main":"index.js"。这里模块我们写的是module.js,我也就懒的改了,所以写成了module。

    var module = require('./example_module');
    console.log(module.dbleNum(3));
    console.log(module.tripleNum(3));

      这样就可以调用example_module这个包了。由于不是通过npm安装,不能直接require('example_module');自己尝试了下,如果新建个node_modules文件夹,把example_module放里面,就可以直接require('example_module'),应该是因为npm安装的包也是会安装到node_modules中的。

    说到现在还没说exports和module.exports的区别,囧。

    如果创建了一个module,想返回其中的一个变量或者函数,将其直接赋给exports是不可以的,如下

    var calcNum = function(){};
    calcNum.prototype.dbleNum=function(num){
        return num*2;
    }
    calcNum.prototype.tripleNum=function(num){
        return num*3;
    }
    exports = calcNum;

    这样是不可以的。但是如果可以将exports换成module.exports就是可行的。此时倒出的calcNum,如果在example.js中调用就要像下面这样子。

    var module = require('module');
    var test = new module;
    console.log(module.dbleNum(3));
    console.log(module.tripleNum(3));

     这是因为exports是module.exports的全局引用,exports.myfunc是module.exports.myfunc的缩略写法。于是,如果将任何函数、对象、变量赋给exports就断开了exports与module.exports的引用关系,而事实上module.exports是真正的出口,所以直接将变量或者函数赋给exports是不可以的(exports.myfunc=myfun是可以的,因为没有切断exports和module.exports的引用关系)。因此,在同一个module中,如果exports和module.exports同时存在,exports是会被忽略的。

     如有错误,欢迎指正。

  • 相关阅读:
    在不给spring管理的类中获取类
    poi操作excel
    闭包
    输入url的过程发生了什么?
    跨域
    函数节流-防抖函数
    预解析-案例
    移动端适配方案
    实现元素水平居中和垂直居中的几种方法
    css小知识点
  • 原文地址:https://www.cnblogs.com/yanbinliu/p/3760413.html
Copyright © 2011-2022 走看看