浅析NodeJs模块化

什么是模块化

模块化指解决一个复杂问题是,自顶向下逐层把系统划分为若干模块的过程。对于整个系统来说,模块是可组合、分解和更换的单元

模块化的优势

  • 提高了代码的复用性
  • 提高了代码的可维护性
  • 可以实现按需加载

Node.js中模块的分类

  • 内置模块(由Node.js官方提供的,例如fs、path、http等)
  • 自定义模块(用户创建的每个js文件都是自定义模块)
  • 第三方模块(由第三方开发出来的模块,使用前需要先下载)

加载模块

// 加载内置的fs模块
const fs = require('fs')

// 加载用户的自定义模块
const custom = require('./custom.js')

// 加载第三方模块,需要先下载
const moment = require('moment')

注意:

  • 使用require()方法来加载其他模块时,会执行被加载模块中的代码。
  • 引入自定义模块时,不能只写模块名,不要忘记写相对路径

模块作用域

与函数作用域类似,在自定义模块中定义的变量、方法等,只能在当前模块中被访问,这种模块级别的访问限制,叫做模块作用域。

作用:防止全局变量污染

向外暴露模块作用域中的成员

module对象

在每个自定义模块中都有一个module对象,它存储了和当前模块有关的信息。

module.exports对象

在自定义模块中,可以使用module.exports对象,将模块内的成员共享出去,供外界使用。

外界用require()方法导入自定义模块时,得到的就是module.exports所指的对象

// index.js

const age = 20
module.exports.age = 18
module.exports.name = 'frank'
// index2.js

const m = require('./index.js')
console.log(m)

在这里插入图片描述
可以看到,在index.js中定义的age没有向外暴露,外界只获取到了module.exports对象中的属性。

导入模块的结果,永远以module.exports指向的对象为准

// index.js

module.exports.name = 'frank'
module.exports.age = '18'

// 让module.exports指向一个全新的对象
module.exports = {
    name:'mike',
    age:20
}
// index2.js

const m = require('./index.js')
console.log(m)

在这里插入图片描述

exports对象

由于module.exports写起来比较复杂,Node提供了exports对象,默认情况下,exportsmodule.exports指向同一个对象,但最终暴露的结果,还是以module.exports指向的对象为准。

exports和module.exports的使用误区

在这里插入图片描述

上图,是四种向外暴露的结果,结合“导入模块的结果,永远以module.exports指向的对象为准”,仔细分析。

(简单地理解:给exports直接赋值是无效的,因为赋值后module.exports仍然是空对象,这里是一个陷阱。)

结论: 为了防止混乱,不要在同一个模块中同时使用exportsmodule.exports

模块化规范CommonJS

Node.js遵循了CommonJS模块化规范,他规定了模块的特性和各模块之间如何相互依赖。

CommomJS规定:

  • 每个模块内部,module变量代表当前模块
  • module变量是一个对象,它的exports属性是对外的接口
  • require()方法用于加载模块
  • 加载某个模块,其实是加载该模块的modele.exports属性
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值