NodeJs——(4)和模块

来源:互联网 发布:java 短链接生成器 编辑:程序博客网 时间:2024/04/29 11:20

(15)模块

当我们制作一个模块时(具体制作方法见前面),我们可能会写一个构造函数(因为在浏览器写构造函数时我们经常会这么做)。

 

如代码:

function sayHello() {    this.say = function () {        console.log('hello');    }}exports.Hello = sayHello;

在这里,我们有一个构造函数sayHello,函数里有一个方法say,输出hello。

 

然后导出的是sayHello这个构造函数。我们在另外一个文件中调用它。

 

代码这么写:

var hello = require('./test').Hello;    //调用刚才写的那个模块var m = new hello();m.say();

 

第一行表示我们调用刚才写的那个模块。

注意,这个时候和之前不同(之前是直接require模块即可),这里需要添加一个Hello。原因在于require表示导入的是一个整体(即有多个exports导出的方法),这里我们只需要其中的Hello方法(即对应原模块中的sayHello这个构造函数);

 

当然,也可以写为require('./test'),在下面的代码,把hello改为hello.Hello即可。

 

第二行代码表示生成一个这个构造函数的实例(还记得js里如何调用构造函数么?构造函数是不能直接调用其方法的);

 

第三行代码表示调用这个实例的say方法(即模块中的this.say=的那个函数);

 

这个流程是:

请求模块——》生成函数的实例——》调用函数的方法

 

 

我们也可以在导出的时候,用另一种方法:

module.exports = sayHello;

 

然后调用这个模块

var hello = require('./test');    //调用刚才导入的那个文件m = new hello();m.say();

 

这个时候hello就是这个函数,然后生成一个实例,调用其方法。

 

但我觉得有个潜在问题,这个模块里只能有这一个函数(不是很确定)。我验证结果如下:

修改之前的模块:

function sayHello() {    this.say = function () {        console.log('hello');    }}function say() {    console.log("say");}module.exports = sayHello;exports.say = say;

调用其的模块:

var hello = require('./test');    //调用刚才导入的那个文件console.log(hello.say)


显示是undefined,而正常情况下(删除module.exports = sayHello;这一行)应该显示:



经过查询,这种用法的作用在于,假如我们只想将一个对象封装到模块中,就这么用。

 

 

另外,不可以直接对exports进行赋值以替代(module.exports这种用法)。

按照说明,这个变量会在模块执行结束后被释放,但module.exports不会。

 


0 0