码迷,mamicode.com
首页 > Web开发 > 详细

Node.js中的模块化

时间:2014-10-16 22:07:13      阅读:778      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   io   os   使用   ar   sp   

每天一篇文章来记录记录自己的成长吧。大二,该静心了。加油~

好了,废话不多说,今天说说nodejs中的模块化.(注:此文为自己对书nodejs实战的总结)

 

nodejs一个重要的特性就是模块化,模块就是node.js对常用功能进行分组的方式。而且,node无需真正辨别模块到底是我们自己编写的还是从外部仓库中获取的。这样我们只需要一个额外的json文档和一两行代码,我们就能引用别人的代码或者别人引用我们的代码,是不是很酷~。

 

好,下面我们来编写一个简单的模块:

exports.hello_world = function(){
    console.log("Hello World");
}

我们用mymodule.js文件来保存这段代码,exports对象是一个特殊的对象,在每个我们创建的文件中由Node的文件系统创建,当我们引用这个模块时,会作为require函数的值返回。它被封装在每个模块的module对象中,用来暴露函数,变量或类。使用模块的方法也很简单,代码如下:

 

var mm = require(‘./mymodule‘);
mm.hello_world();

这样我们可以通过exports对象来暴露任何我们想要暴露的函数和类。当我们频繁的从模块中返回对象时,我们会有两种使用的核心模式:

第一种就是我们的工厂模式,看下面一段代码:

bubuko.com,布布扣
function Hello(lang){
    this.language  = lang;
    this.greet() = function(){
        switch(this.language){
            case "en" :return "Hello1";break;
            case "de" :return "Hello2";break;
            case "jp" :return "Hello3";break;
            default:return "No speaka that language";break;
        }
    }
}


//现在我们用工厂模式来返回我们Hello类的实例
exports.create_Hello = function(lang){
    return new Hello(lang);
}
View Code

这种模式的有点事模块可以通过exports对象来暴露其他的函数和类。

第二种模式就是构造函数模式,即直接模式,现在我们函数不变,用构造函数代码就应是这样:

module.exports = Hello;

注意我们在使用的时候就应该把代码变一下:

var hello = require("./mymodule");
var lang = "en";
var obj = new hello(lang);
obj.greet();

但记住在这里我们真正唯一暴露的是一个类的构造函数。这和我们面向对象的思想很接近,但是有个缺点就是我们不能让模块暴露更多的东西。所以我们经常会用的是我们的工厂模式。

关于exports和module.exports的区别大家来看这个网址:https://cnodejs.org/topic/52308842101e574521c16e06.

 

我们知道了想要在一个文件中引入模块我们只需使用require函数即可,注意我们引入的模块对于引入他们的模块时私有的。如果a.js加载http模块,那么b.js是无法加载这个模块的,除非b也引入了http模块。

下面看看Node.js是怎样来查找模块的,其实规则很简单:

1.当请求的是内置模块(如http和fs)时,node会直接使用这些模块

2.当请求的模块一路径符(如./  ../  /)开始时,node会找到指定的目录并且加载他,如果没有在模块名中指定.js扩展名,那么node会首先查找基于同名文件夹的模块,如果没有找到,那么他会添加扩展名.js .json和.node,并尝试一次加载这些模块(带node扩展名的模块会被编译成附加模块)

3.如果没有路径符,node会在当前文件夹的node_modules/子文件夹下查找模块。如果找到,则加载该模块,否则,node会以自己的方式在当前位置的路径树下寻找mode_modules/文件夹,如果还失败,那么他会在一些默认的地址下进行搜寻,如/usr/lib和/usr/local/lib文件夹.

4.如果还没找到就抛出错误.

 

以前我们在引用文件时很容易进入引用文件死循环,但是在node中却不会这样。比如我在a.js中引入b.js,在b.js中引入a.js,在main.js中引入a.js,这个在node 中的执行顺序是先加载main.js,然后运行 引入a.js,再引入b.js,然后node会检测到循环并返回一个指向a.js的对象,但是不会再执行此代码。

 

我们知道node.js的每个文件都是一个含有module和exports对象的模块,这个模块也可以很复杂:包含一个目录用来保存模块的内容和一个包含包信息的文件。如果我们想要编写一系列的支持文件,并将模块的功能拆散到多个js文件中,甚至包含单元测试,那么我们可以这么来写:

1.创建一个文件夹来存放模块的内容

2.添加一个名为package.json的文件到文件夹中。文件至少包含当前模块的名字和一个主要的JS文件(用来一开始加载该模块)

3.如果Node没有找到package.json文件或者没有指定主JS文件,那他就会查找index.js(或者是编译后的附加模块index.node)

 

当然模块的内容不止这么一点点,剩下的以后再补充吧。

Node.js中的模块化

标签:style   blog   http   color   io   os   使用   ar   sp   

原文地址:http://www.cnblogs.com/xiaofanguoguo/p/4029599.html

(1)
(1)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!