(三)Node.js - 模块化

1. Node.js中的模块化

Node.js中根据模块来源不同,将模块分为了3大类,分别是:

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

2. 加载模块

使用强大的require()方法,可以加载需要的内置模块、用户自定义模块、第三方模块进行使用。例如:

javascript 复制代码
//1. 加载内置的fs模块
const fs = require('fs')
//2. 加载用户的自定义模块
const custom = require('./custom.js')
//3. 加载第三方模块
const moment = require('moment')

3. 什么是模块作用域

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

好处:防止全局变量污染问题,默认情况下,无法访问导入模块的变量和函数

3.1 向外共享模块作用域中的成员

1. module对象

在每一个.js自定义模块中都有一个module对象,它里面存储了和当前模块有关的信息,打印如下:

javascript 复制代码
console.log(module)

//日志
Module {
  id: '.',
  path: '/Users/xxx/WebstormProjects/learnJS/5.nodeJS',
  exports: {},
  filename: '/Users/xxx/WebstormProjects/learnJS/5.nodeJS/3.module对象.js',
  loaded: false,
  children: [],
  paths: [
    '/Users/xxx/WebstormProjects/learnJS/5.nodeJS/node_modules',
    '/Users/xxx/WebstormProjects/learnJS/node_modules',
    '/Users/xxx/WebstormProjects/node_modules',
    '/Users/xxx/node_modules',
    '/Users/node_modules',
    '/node_modules'
  ]
}
2. module.exports对象

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

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

自定义模块.js

javascript 复制代码
//在一个自定义模块中,默认情况下,module.exports = {}


//方式一:
//向module.exports对象上挂载username属性
module.exports.username = 'zs'
//向module.exports对象上挂载sayHello方法
module.exports.sayHello = function () {
    console.log('Hello')
}

//方式二:
module.exports = {
    username: 'zs',
    sayHello: function () {
        console.log('Hello')
    }
}

test.js

javascript 复制代码
//在外界使用require导入一个自定义模块的时候,得到的成员
//就是那个模块中,通过module.exports指向的那个对象
const m = require('./自定义模块')
console.log(m)

打印:

bash 复制代码
{ username: 'zs', sayHello: [Function: sayHello] }
3. 共享成员时的注意点

使用require()方法导入模块时,导入的结果,永远以module.exports指向的对象为准。

4. exports对象

由于module.exports单词写起来比较复杂,为了简化向外共享成员的代码,Node提供了exports对象。默认情况下,exports和module.exports指向同一个对象。最终共享的结果是,还是以module.exports所指的对象为准。

javascript 复制代码
console.log(exports)
console.log(module.exports)
console.log(exports === module.exports)

{}
{}
true

挂载属性:

bash 复制代码
exports.username = 'zs'
exports.sayHello = function (){
    console.log('hello')
}
5. exports和module.exports的使用误区

时刻谨记,require()模块时,得到的永远是module.exports指向的对象:

javascript 复制代码
//案例一:
exports.username = 'zs'
module.exports = {
	gender: '男',
	age:22
}

//{gender: '男', age: 22}

//案例二:
module.exports.username = 'zs'
exports = {
	gender: '男',
	age:22
}

//{username: 'zs'}

//案例三:
exports.username = 'zs'
module.exoprts.gender = '男'

//{username: 'zs', gender: '男'}

//案例四:
exports = {
	username: 'zs',
	gender: '男'
}
module.exports = exports
module.exports.age = '22'

//{username: 'zs', gender: '男', age: '22'}

4. Node.js中的模块化规范

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

CommonJS规定:

(1)每个模块内部,module变量代表当前模块。

(2)module变量是一个对象,它的exports属性(即module.exports是对外的接口

(3)加载某个模块,其实是加载该模块的module.exports属性。require()方法用于加载模块

相关推荐
胡西风_foxww3 小时前
Node.js聊天室开发:从零到上线的完整指南
websocket·node.js·express·聊天室
c_zyer15 小时前
使用 nvm 管理 Node.js 和 npm 版本
前端·npm·node.js
小刘不知道叫啥17 小时前
简单说一下 Webpack分包
前端·javascript·webpack·node.js
Dontla17 小时前
《黑马前端ajax+node.js+webpack+git教程》(笔记)——node.js教程+webpack教程(nodejs教程)
前端·ajax·node.js
MessiGo17 小时前
Javascript 编程基础(2)基础知识 | 2.1、javascript与Node.js
开发语言·javascript·node.js
xcs1940518 小时前
开发 前端搭建npm v11.4.0 is known not to run on Node.js v14.18.1.
前端·npm·node.js
Dontla20 小时前
《黑马前端ajax+node.js+webpack+git教程》(笔记)——ajax教程(axios教程)
前端·ajax·node.js
Java-云海20 小时前
Windows环境使用NVM高效管理多个Node.js版本
vscode·npm·node.js·nvm
打小就很皮...21 小时前
基于 Vue 和 Node.js 实现图片上传功能:从前端到后端的完整实践
前端·vue.js·node.js
霸王蟹1 天前
常见面试题:Webpack的构建流程简单说一下。
前端·笔记·学习·webpack·node.js·vue