node.js模块的加载机制
2021/9/21 11:26:53
本文主要是介绍node.js模块的加载机制,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1. 优先从缓存中加载模块
模块在第一次加载后会被缓存,即多次调用require()方法不会导致模块的代码被执行多次。
不论是内置模块,用户自定义模块或第三方模块,它们都会优先从缓存中加载,从而提高模块的加载效率。
2. 内置模块的加载机制
内置模块是由node.js官方提供的模块,内置模块的加载优先级最高。
例如,即使在node_modules目录下有同名的第三方模块,require(‘fs’)也始终返回内置的fs模块。
3. 自定义模块的加载机制
当调用require()方法加载自定义模块时,必须指定以./或…/开头的路径标识符,如果没有路径标识符,则node.js会把它当作内置模块或第三方模块加载。
如果导入自定义模块时省略了文件的拓展名,则node.js会按顺序分别尝试加载以下的文件:
- 按照确切的文件名加载
- 补全.js拓展名加载
- 补全.json拓展名加载
- 补全.node拓展名加载
- 加载失败,终端报错
4. 第三方模块的加载机制
如果传递给require()的不是node.js的一个内置模块,也没有路径标识符,则node.js会从当前模块的父目录开始,尝试从/node_modules文件夹中加载第三方模块。
如果没有找到对应的第三方模块,则移动到再上一层父目录中,进行加载,直到文件系统的根目录中。
即从当前目录开始,寻找node_modules文件夹,找不到就从上级目录中找,直到文件根目录中,找到后就会加载对应的第三方模块。
这篇关于node.js模块的加载机制的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-15useCallback教程:React Hook入门与实践
- 2024-11-15React中使用useContext开发:初学者指南
- 2024-11-15拖拽排序js案例详解:新手入门教程
- 2024-11-15React中的自定义Hooks案例详解
- 2024-11-14受控组件项目实战:从零开始打造你的第一个React项目
- 2024-11-14React中useEffect开发入门教程
- 2024-11-14React中的useMemo教程:从入门到实践
- 2024-11-14useReducer开发入门教程:轻松掌握React中的useReducer
- 2024-11-14useRef开发入门教程:轻松掌握React中的useRef用法
- 2024-11-14useState开发:React中的状态管理入门教程