今天看了一下node.js的书,理解了模块化的意思,之前在项目中,不论是react-native还是vue,只要是看见exports和require,总是一头雾水,今天就来解释一下,来加深一哈理解。
1.为何要进行模块化? 模块化就是将功能进行拆解,再组合的过程。因为一个项目不可能总是由一个文件构成的,模块化可以更好地服务于你。
2.模块化的两种方法:
第一种方法最简单的就是创建两个文件,在另外一个文件中引用这个文件,并调用这个模块中的方法。
举个栗子:
在module.js中有这样的代码:
//module.js
var name;
exports.setName = function(BName) {
name = BName;
};
exports.sayHello = function() {
console.log('看你不爽的 ' + name);
};
在另外一个文件getModule.js中:
//getmodule.js
var myModule = require('./module'); //在同一目录文件下
myModule.setName('Bacon');
myModule.sayHello();
运行node getmodule.js,可也以安装supervisor,可以进行实时调试,很舒服。
输出结果是:
看你不爽的 Bacon
第二种方法就是进行封装,再来看:
//capsuleModule.js
function fSBacon() {
var name;
this.setName = function (BName) {
name = BName;
};
this.sayHello = function () {
console.log('依然看你不爽的 ' + name);
};
};
module.exports = fSBacon;
注:也可用exports.Hello = Hello; 不可以通过对 exports 直接赋值代替对 module.exports 赋值。 exports 实际上只是一个和 module.exports 指向同一个对象的变量, 它本身会在模块执行结束后释放,但 module 不会,因此只能通过指定 module.exports 来改变访问接口。
在另外一个文件getCapsuleModule.js中:
//getCapsuleModule.js
var fSBacon = require('./ capsuleModule’);
bacon = new fSBacon ();
bacon.setName('Bacon');
bacon.sayHello();
接管依然如是。
今天要写的就这么些喽,主要是对模块化和封装有了一些更深的认识,知道的太少。
然而秋招的脚本更近了……,实习还没有着落......
网友评论