Node.js 模块查找策略(require 完整流程)

Node.js 模块查找策略(require 完整流程)

Node.js 使用 require() 导入模块时,会按固定优先级逐级查找,找不到则抛出 Cannot find module 错误。


一、整体查找顺序(4 大步骤)

优先级 步骤 说明
1 内置模块 直接命中核心模块,不往下走
2 文件查找 ./ ../ / 开头的路径
3 文件夹查找 文件找不到时把路径当文件夹处理
4 node_modules 非路径、非内置 → 逐级向上查找

二、详细查找规则

1. 内置模块(核心模块)

条件: 直接写模块名(非路径写法),且是 Node 内置模块。

直接加载,不往下查找。常见内置模块:

fs path http url querystring crypto events stream os

js 复制代码
const fs = require('fs');  // 直接命中内置模块

2. 文件查找(路径以 ./ ../ / 开头)

按精确路径找文件,自动补后缀:

复制代码
.js → .json → .node

都找不到则进入文件夹查找

js 复制代码
require('./a')

// 查找顺序:
//   ./a → ./a.js → ./a.json → ./a.node → 把 a 当文件夹

3. 文件夹查找

把路径当作文件夹,按以下规则找入口文件:

  1. 看文件夹下是否有 package.json
    • 有 → 读取 main 字段作为入口文件
    • 无 → 进入下一步
  2. index.jsindex.jsonindex.node
  3. 仍找不到 → 抛出模块未找到错误
js 复制代码
// ./a/package.json
{ "main": "k.js" }

require('./a')  // → 加载 ./a/k.js

4. 第三方模块(node_modules)

条件: 非路径、非内置模块。

查找规则:

  1. 从当前目录的 node_modules 开始找
  2. 找不到 → 向上一级目录的 node_modules
  3. 一直递归到磁盘根目录
  4. 找到后,重复「文件查找 → 文件夹查找」
  5. 根目录都没有 → 报错
js 复制代码
require('lodash')

// 当前目录 node_modules → 上级 → ... → 根目录 node_modules

三、极简伪代码(面试背诵版)

markdown 复制代码
require(X)

1. X 是内置模块 → 加载,结束

2. X 以 ./ ../ / 开头
   → 找文件(补后缀 .js .json .node)
   → 找文件夹(package.json main / index.js .json .node)
   → 找不到 → 报错

3. 否则
   → 逐级向上找 node_modules/X
   → 找到后走文件/文件夹查找
   → 找不到 → 报错
相关推荐
gogoing1 小时前
await fetch() 的两阶段设计
前端·javascript
gogoing1 小时前
前端首屏加载优化
前端·javascript
gogoing1 小时前
重排与重绘
前端·javascript
zhangfeng11332 小时前
小龙虾 wordbuddy 安装浏览器控制器 agent-browser npm install -g agent-browse
前端·人工智能·npm·node.js
之歆3 小时前
DAY_18深度解析:数据类型转换与运算符全攻略(上)
前端·javascript
大家的林语冰3 小时前
pnpm 11 发布,弃用 JSON 和 npm CLI,进化为纯 ES6 模块,新增 pnpm pack-app 等命令,供应链保护默认启用,要求 Node
前端·javascript·node.js
Alice-YUE3 小时前
深入解析 JS 事件循环:浏览器与 Node.js 的差异全解析
前端·javascript·笔记·学习
HYCS3 小时前
用pixijs实现fabricjs(二):对象的基础位置信息
前端·javascript·canvas
Alice-YUE4 小时前
【无标题】
开发语言·javascript·ecmascript