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 分钟前
Electron 开发实战(六):系统交互与原生功能实战全解
前端·javascript·electron
爱喝热水的呀哈喽2 分钟前
npm 双网切换
前端·npm·node.js
Rain50916 分钟前
mini-cc 权限安全:给 AI 戴上枷锁
前端·人工智能·安全·架构·node.js·ai编程
wyc是xxs23 分钟前
用纯 Node.js 写了一个 JS 解释器 — kernel-js-lite
开发语言·javascript·npm·node.js
之歆32 分钟前
Day01_ES6+ 专业指南:从基础到实战的现代JavaScript开发(上)
javascript·mysql·es6
weixin_BYSJ198732 分钟前
基于Django的非物质文化遗产管理系统设计与实现(源码 + 文档)98950
java·javascript·spring boot·python·django·flask·php
এ慕ོ冬℘゜32 分钟前
从零封装企业级通用确认弹窗组件|高复用、低耦合、适配全场景
开发语言·前端·javascript
Tiffany_Ho1 小时前
Derek-Callan-business-english: 用现代前端技术打造高效商务英语学习平台
前端·typescript·node.js
weixin_BYSJ19871 小时前
springboot鹿邑县旅游网站99312(源码+文档)
java·javascript·spring boot·python·django·flask·php
晓得迷路了1 小时前
栗子前端技术周刊第 131 期 - pnpm 11.3、npm 11.16.0、Astro 6.4...
前端·javascript·css