例如:这是rocker.js文件
在另一个文件中你这样引用
其实, Module.exports 才是真正的接口, exports 只不过是它的一个辅助工具。最终返回给调用的是 Module.exports 而不是 exports 。
注意:
所有的exports收集到的属性和方法,都赋值给了Module.exports。当然,这有个前提,就是Module.exports本身不具备任何属性和方法。如果,Module.exports已经具备一些属性和方法,那么exports收集来的信息将被忽略。
例如:
会以对象(也可叫字典)输出
如果你想在module.js中使用outputA或outputB函数,就得
上面的写法也等同于
exports收集到的属性和方法,并未都赋值给了Module.exports,因为Module.exports已经具备一些属性和方法,因此exports收集来的信息将 被忽略
再次引用执行rocker.js
下面例子中,你的模块是一个类: 想导出的模块为特定的数组类型
可以这样应用它:
下面例子中,你的模块是一个数组: 想导出的模块为特定的数组类型
可以这样应用它
结论: 现在你明白了,如果你 想你的模块是一个特定的类型 就用Module.exports。如果你想的模块是一个典型的“实例化对象”就用exports。
//写法1exports.hello = function(){
console.log(‘world’)
}
//写法2
var f = {
hello : function(){
console.log(‘world’)
}
}
module.exports = f
假设我们写的这个模块的文件名为hello.js,执行下面的代码
var h = require(‘hello’)
h.hello()
对于上面的两种写法,执行这段代码后得出的结果是一样的。