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

    1. 返回一个JSON Object

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

       var exp = {
      "version": "1.0.0",
      "function1": null,
      "module1": null,
      };
      module.exports = exp;

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

       // MATH.js
      var MATH = {
      "pi": 3.14,
      "e": 2.72,
      }; module.exports = MATH;

      调用方式为

       var MATH = require("./MATH")
      console.log(MATH.pi);

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

       // module_collection.js
      var module_collection = {
      "module1": require("./module1"),
      "module2": require("./module2"),
      }; module.exports = module_collection;

      调用方式为

       var module_collection = require("./module_collection");
      var module1 = module_collection.module1;
      var module2 = module_collection.module2;
      // Do something with module1 and module2

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

       // functions.js
      var func1 = function() {
      console.log("func1");
      }; var func2 = function() {
      console.log("func2");
      }; exports.function1 = func1;
      exports.function2 = func2;

      调用方式为

       var functions = require("./functions");
      functions.function1();
      functions.function2();
    2. 返回一个构造函数,也就是一个类

      如下是一个简单的示例。

       // CLASS.js
      var CLASS = function(args) {
      this.args = args;
      } CLASS.prototype.func = function() {
      console.log("CLASS.func");
      console.log(this.args);
      }; module.exports = CLASS;

      调用方法为

       var CLASS = require("./CLASS")
      var c = new CLASS("arguments");
    3. 返回一个普通函数

      如下是一个简单的示例

       // func.js
      var func = function() {
      console.log("this is a testing function");
      }; module.exports = func;

      调用方法为

       var func = require("./func");
      func();
    4. 返回一个对象object

      如下是一个简单的示例

       // CLASS.js
      var CLASS = function() {
      this.say_hello = "hello";
      }; CLASS.prototype.func = function() {
      console.log("I say " + this.say_hello);
      }; module.exports = new CLASS();

      调用方法为

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

单例模式

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

 // MATH.js
var MATH = {
"pi": 3.14,
"e": 2.72,
}; module.exports = MATH;

以及

 // CLASS.js
var CLASS = function() {
this.say_hello = "hello";
}; CLASS.prototype.func = function() {
console.log("I say " + this.say_hello);
}; module.exports = new CLASS();

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

Node.js中的模块接口module.exports浅析的更多相关文章

  1. Node.js中的模块接口module.exports

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

  2. node.js中express模块创建服务器和http模块客户端发请求

    首先下载express模块,命令行输入 npm install express 1.node.js中express模块创建服务端 在js代码同文件位置新建一个文件夹(www_root),里面存放网页文 ...

  3. node.js中ws模块创建服务端和客户端,网页WebSocket客户端

    首先下载websocket模块,命令行输入 npm install ws 1.node.js中ws模块创建服务端 // 加载node上websocket模块 ws; var ws = require( ...

  4. node.js中net模块创建服务器和客户端(TCP)

    node.js中net模块创建服务器和客户端 1.node.js中net模块创建服务器(net.createServer) // 将net模块 引入进来 var net = require(" ...

  5. 在 Node.js 中引入模块:你所需要知道的一切都在这里

    本文作者:Jacob Beltran 编译:胡子大哈 翻译原文:http://huziketang.com/blog/posts/detail?postId=58eaf471a58c240ae35bb ...

  6. Web 前端模块出现的原因,以及 Node.js 中的模块

    模块出现原因 简单概述 随着 Web 2.0 时代的到来,JavaScript 不再是以前的小脚本程序了,它在前端担任了更多的职责,也逐渐地被广泛运用在了更加复杂的应用开发的级别上. 但是 JavaS ...

  7. node.js中通过dgram数据报模块创建UDP服务器和客户端

    node.js中 dgram 模块提供了udp数据包的socket实现,可以方便的创建udp服务器和客户端. 一.创建UDP服务器和客户端 服务端: const dgram = require('dg ...

  8. node.js中net网络模块TCP服务端与客户端的使用

    node.js中net模块为我们提供了TCP服务器和客户端通信的各种接口. 一.创建服务器并监听端口 const net = require('net'); //创建一个tcp服务 //参数一表示创建 ...

  9. node.js中module模块的理解

    node.js中使用CommonJS规范实现模块功能,一个单独的文件就是一个单独的模块.通过require方法实现模块间的依赖管理. 通过require加载模块,是同步操作. 加载流程如下: 1.找到 ...

随机推荐

  1. windows下Oracle数据库完全删除

    1.1   停止所有oracle的服务 1.2   删除安装路径 app及其下所有文件 1.3   删除注册表 regedit 进入 在下列列表中找到与oracle相关的注册表项删除 1.HKEY_L ...

  2. 解决css3不支持同时缩放和旋转的办法

    设置两个div,外层scale,内层rotate.

  3. 关于矩阵A*b=A*c 中b是否等于c

    注意如果A各列线性无关那么b=c,反之b!=c, 针对最小二乘中的   p=A * roof_x        A' ( b-p)=0  =>   A'b =A' p 如果  两边同乘以A  , ...

  4. java常用设计模式十:模板模式

    一.定义 定义一个操作中的算法的骨架,而将一些步骤延迟到子类中.模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤. 如果上面的话不好理解,请看下面的例子 二.示例 1)定义一个模 ...

  5. vs2015转到定义没反应

    开始菜单 -->所有程序-->Visual Studio 文件夹 --> Visual Studio Tools -->VS2015开发人员命令提示输入DOS命令: CD Co ...

  6. vue的饿了么写作感受

    1.在重复使用的组件中,要把重复使用组件的需要在数据的请求的地方设置为在富组件中,通过props船只到子组件,这样在重复调用次组件的时候既可以很好的避免组件的值的冲突 2.getData的使用,把所有 ...

  7. call和apply的作用实例

    <script> var scopeTest = function(){ //考察了 this 的含义 window.a=2; function fn(b){ this.b = b; co ...

  8. DOM3级的变化

    由于存在跨浏览器开发问题所以不推荐使用: 兼容性: event.key 包含所按下键的字符 event.char 属性IE9和safari和chrome并不支持 event.location 返回所按 ...

  9. Linux中的sleep、usleep、nanosleep、poll和select

    在进行Linux C/C++编程时,可调用的sleep函数有好多个,那么究竟应当调用哪一个了?下表列出了这几个函数间的异同点,可作为参考: 性质 精准度 线程安全 信号安全 sleep libc库函数 ...

  10. activeMq之hello(java)

    消息队列activeMq,   节省响应时间,解决了第三方响应时间长的问题让其他客户可以继续访问, 安装activeMq apache-activemq-5.14.0-bin\apache-activ ...