本篇文章主要讲解一下nodejs中的模块导入导出问题:
一、模块导出的方式
方式1:
导出部分
module.exports.name = "wh";
接收内容
{ name: 'wh' }
方式2:
导出部分
module.exports = {
name:"wh"
}
接收内容:
{ name: 'wh' }
方式3
无导出部分,在另外一个模块直接加载该模块,然后自定义一个属性,再次加载,然后打印
var s = require('./exports');
s.name="san";
s = require('./exports');
console.log(s);
//打印输出结果
{ name: 'san' }
方式4
exports.msg ="wh";
打印输出结果
{ msg: 'wh'}
注意:
exports = 200;这种写法错误,为啥呢?我们看下module.exports的实现过程:
// 准备module对象:
var module = {
id: 'hello',
exports: {}
};
var load = function (module) {
// 读取的hello.js代码:
function greet(name) {
console.log('Hello, ' + name + '!');
}
module.exports = greet;
// hello.js代码结束
return module.exports;
};
var exported = load(module);
// 保存module:
save(module, exported);
从上面的实现过程可以看出,最终返回了一个空对象
由于node底层也定义了一个变量exports,如果直接赋值就相当于切断了关联
总结:
1 module.exports=导出内容
你再进行引用的时候就是你导出的实际内容了
如果导出类名,调用的时候你就需要new一个实例,如果是导出的是实例,你可以直接调用实例下面的某些方法了
2 直接使用module.exports如果导出的是一个数值或者字符串,那么require接收的就只是一个数值或者字符串;如果导出的是一个函数或者类,那么接收的就是一个函数或者
//导出:
function test(){
}
test.prototype={
age(){
return 18;
}
}
module.exports = new test();
//引入:
var s = require('./exports');
s = new s();
console.log(s.age()); 打印输出18
exports.js
module.exports = (function(){
return {age:15};
})()
main.js
var s = require('./exports');
s.name = 100;
s = require('./exports');
console.log(s);
//结果:
{ age: 15, name: 100 }
二、导出类,函数,数值,字符串的区别
1 导出一个es6的类:
导出部分 exports.js
class test{
age(){
return 22;
}
}
module.exports = new test();
接收部分 main.js
var s = require('./exports');
s.name="wh";
console.log(s,s.name);
打印输出:
test { name: 'wh' } 'wh'
2 导出一个es5的类
exports.js–导出部分
function test(){
}
test.prototype={
age(){
return 18;
}
}
module.exports = new test();
main.js–接收部分
var s = require('./exports');
s.name="wh";
console.log(s,s.name);
{ name: "wh"} "wh"
3 导出一个函数
exports.js
function abc(){
return 22;
}
module.exports = abc;
main.js
var s = require('./exports');
console.log(s,s());
[Function: abc] 22