为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文件包含的代码比较少,在node中,一个js文件就是一个模块module,
当一个模块编写完毕,就可以被其他地方引用。我们在编写程序的时候,也经常引用其他模块,包括Node内置的模块和来自第三方的模块。
使用模块还可以避免函数名和变量名冲突,相同名字的函数和变量可以分别存在不同的模块中,因此,我们自己在编写模块时,不必考虑名字会与其他模块冲突。
hello.js中 模块名字就是hello 我们可以将该模块暴露出去,给外部使用。
'use strict';
var s = 'hello';
function name(name){
console.log(s + ',' + name);
}
module.exports = greet;
最后一句话的意思就是,把greet暴露出去,这样其他模块就可以使用greet函数了。
其他模块使用hello中的greet函数。
'use strict';
//引入hello模块
var greet = require('./node');
greet('ckq');
引入的模块作为变量存在于greet变量中,greet变量是hello.js中我们导出的module.exports = greet 所以main.js就成功地引用了hello.js
模块中定义的greet()
函数,接下来就可以直接使用它了。
在使用require()引入模块的时候,请注意模块的相对路径,因为main和hello位于同一个目录下,所以我们用了当前目录.
如果只写模块名,var greet = require('hello');
则node会依次在内置模块,全局模块和当前模块下查找hello.js,很可能会得到一个错误。
这种模块加载的机制被称为commonjs规范,每个.js文件都是一个模块,他们内部各自使用的变量名和函数名互相不冲突,例如hello.js中的变量名xxx 和main.js中的变量名xxx就是互相不冲突的。
一个模块想要对外暴露变量,函数也是变量,可以用module.exports = variable,一个模块要引用其他模块中的变量,就要使用
var ref = require('./module_name'); 就拿到了引用模块的变量。
结论
要在模块中对外输出变量,用:
module.exports = variable;
输出的变量可以是任意对象、函数、数组等等。
要引入其他模块输出的对象,用:
var foo = require('other_module');
引入的对象具体是什么,取决于引入模块输出的对象。
node 利用了js的函数式编程的特性,原来的全局变量现在就变成了匿名函数内部的局部变量。
如果Node.js继续加载其他模块,这些模块中定义的“全局”变量s
也互不干扰。