node之模块化

一、介绍

1.1 什么是模块化与模块?

将一个复杂的程序文件依据一定规则(规范)拆分成多个文件的过程称之为 模块化

其中拆分出的 每个文件就是一个模块 ,模块的内部数据是私有的,不过模块可以暴露内部数据以便其他模块使用

1.2 什么是模块化项目?

编码时是按照模块一个一个编码的, 整个项目就是一个模块化的项目

1.3 模块化好处

下面是模块化的一些好处:

  1. 防止命名冲突
  2. 高复用性
  3. 高维护性

二、模块化初体验

javascript 复制代码
function testFuc(params) {
  console.log('test......')
}

module.exports = testFuc
javascript 复制代码
const test = require('./test')

test() //test......

三、模块暴露数据

模块暴露数据的方式有两种:

  1. module.exports = value
  2. export.name = value

使用时有几点需要注意:

  • module.exports 可以暴露任意数据
  • 不能使用 exports = value 的形式暴露数据,模块内部 module 与 exports 的影式关系exports = module.exports = {},require 返回的是目标模块中 module.exports的值
javascript 复制代码
function testFuc(params) {
  console.log('test......')
}

function niejiao(params) {
  console.log('捏脚')
}

// 1. module.exports = xxx
// module.exports = {
//   testFuc,
//   niejiao
// }

// 2. exports.xxx = xxx
exports.testFuc = testFuc
exports.niejiao = niejiao

// 3. exports = module.exports = {}

四、导入模块

在模块中使用 require 传入文件路径即可引入文件

javascript 复制代码
const test = require('./me.js');

require 使用的一些注意事项:

1.1 导入文件

  1. 对于自己创建的模块,导入时路径建议写相对路径 ,且不能省略 ./ ../
  2. js json 文件导入时可以不用写后缀,c/c++编写的 node 扩展文件也可以不写后缀,但是一般用不到(同名,优先js 文件 => json)
  3. 如果导入其他类型的文件,会以js文件进行处理(其它类型文件,如果有后缀名,导入时不能省略)

1.2 导入文件夹

  1. 如果导入的路径是个文件夹,则会首先检测该文件夹下 package.json 文件中 main 属性对应的文件,如果存在则导入,反之如果文件不存在会报错。
    如果 main 属性不存在,或者 package.json 不存在,则会尝试导入文件夹下的 index.js
    index.json
    如果还是没找到,就会报错
  2. 导入 node.js 内置模块时,直接 require 模块的名字即可,无需加 ./ ../

五、require 导入的基本流程

这里我们介绍一下 require 导入 自定义模块 的基本流程

  1. 将相对路径转为绝对路径,定位目标文件
  2. 缓存检测
  3. 读取目标文件代码
  4. 包裹为一个函数并执行(自执行函数)。通过 arguments.callee.toString() 查看自执行函数
  5. 缓存模块的值
  6. 返回 module.exports 的值
javascript 复制代码
/**
 * 伪代码
 */

function require(file){
  //1. 将相对路径转为绝对路径,定位目标文件
  let absolutePath = path.resolve(__dirname, file);
  //2. 缓存检测
  if(caches[absolutePath]){
    return caches[absolutePath];
  }
  //3. 读取文件的代码
  let code = fs.readFileSync(absolutePath).toString();
  //4. 包裹为一个函数 然后执行
  let module = {};
  let exports = module.exports = {};
  (function (exports, require, module, __filename, __dirname) {
    const test = {
      name: '尚硅谷'
    }
  
    module.exports = test;
  
    //输出
    console.log(arguments.callee.toString());
  })(exports, require, module, __filename, __dirname)
  //5. 缓存结果
  caches[absolutePath] = module.exports;
  //6. 返回 module.exports 的值
  return module.exports;
}

const m = require('./me.js');

六、CommonJS 模块化规范

module.exports 、 exports 以及 require 这些都是 CommonJS 模块化规范中的内容。

而 Node.js 是实现了 CommonJS 模块化规范,二者关系有点像 JavaScript 与 ECMAScript

相关推荐
尘世中一位迷途小书童1 分钟前
JavaScript 一些小特性:让你的代码更优雅高效
前端·javascript·架构
草帽lufei3 分钟前
高强度SOLO真实业务项目
前端·ai编程·trae
1024肥宅3 分钟前
告别异地登录告警!用 GitHub Self-Hosted Runner 打造“零打扰”全栈自动化部署
前端·后端·github
GDAL5 分钟前
CSS重置样式表(Reset CSS
前端·css
SpringLament8 分钟前
TanStack Virtual 源码解析:定高/不定高虚拟列表实现原理以及框架无关设计
前端·javascript
猪猪拆迁队8 分钟前
高性能 Package构建系统设计与实现
前端·后端·node.js
用户144361834009710 分钟前
你不知道的JS-上(五)
javascript·程序员
UIUV12 分钟前
JavaScript中instanceof运算符的原理与实现
前端·javascript·代码规范
Dr_哈哈12 分钟前
🔥彻底搞懂 AI Agent!LangGraph 从入门到实战(附完整源码)
langchain·node.js·agent
前端fighter13 分钟前
全栈项目:闲置二手交易系统(一)
前端·vue.js·后端