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
   → 找到后走文件/文件夹查找
   → 找不到 → 报错
相关推荐
胡萝卜术2 小时前
滑动窗口最大值:从暴力到单调队列,层层优化全解析
前端·javascript·面试
kyriewen3 小时前
2026 年了,这 6 个 npm 包可以卸载了——浏览器原生 API 已经能替代
前端·javascript·npm
铁皮饭盒4 小时前
bun直接tsx,优雅!
javascript·后端
_柳青杨6 小时前
一文吃透 Node.js 事件循环:从原理到 Node 20+ 重大变更
javascript·后端
JieE21216 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
冬奇Lab18 小时前
AI Workflow 定义的四次演进:从 Markdown 到 JS 脚本,再到分布式多 Agent
javascript·人工智能·agent
一颗烂土豆1 天前
Meshopt 压缩深度解析,为什么它比 Draco 更快
前端·javascript·webgl
kyriewen1 天前
同事每天催我 Code Review,我写了个脚本让 AI 替我 review PR——现在他反过来催 AI 了
前端·javascript·ai编程
米丘1 天前
vite8 vite preview 命令做了什么?
node.js·vite
weedsfly1 天前
迭代器、生成器与异步迭代——让数据“按需流动”的艺术
前端·javascript