node.js(3) 模块加载机制
2015-10-27 09:56
615 查看
Node.js 的模块可以分为两大类,一类是核心模块,另一类是文件模块。
文件模块的加载有两种方式,一种是按路径加载,一种是查找 node_modules 文件夹。
如果 require 参数以“/ ”开头,那么就以绝对路径的方式查找模块名称,例如require(‘/home/byvoid/module’) 将 会 按照 优 先 级 依次 尝 试 加 载 、/home/byvoid/module.js、/home/byvoid/module.json 和 /home/byvoid/module.node。
如果 require 参数以“./ ”或“../ ”开头,那么则以相对路径的方式来查找模块,这种方式在应用中是最常见的。例如前面的例子中我们用了require(‘./hello’)来加载同一文件夹下的hello.js。
令,
Node.js会依次查找:
/home/byvoid/develop/node_modules/bar.js
/home/byvoid/node_modules/bar.js
/home/node_modules/bar.js
/node_modules/bar.js
核心模块
核心模块就是Node.js 标准 API 中提供的模块,如 fs、 http、 net、 vm 等,这些都是由 Node.js 官方提供的模块,编译成了二进制代码。我们可以直接通过 require 获取核心模块,例如require(‘fs’)。核心模块拥有最高的加载优先级,换言之如果有模块与其命名冲突,Node.js 总是会加载核心模块。文件模块
文件模块则是存储为单独的文件(或文件夹)的模块,可能是 JavaScript 代码、 JSON 或编译好的 C/C++ 代码。文件模块的加载方法相对复杂,但十分灵活,尤其是和 npm 结合使用时。在不显式指定文件模块扩展名的时候, Node.js 会分别试图加上 .js、 .json 和 .node扩展名。 .js 是 JavaScript 代码, .json 是 JSON 格式的文本, .node 是编译好的C/C++ 代码。文件模块的加载有两种方式,一种是按路径加载,一种是查找 node_modules 文件夹。
如果 require 参数以“/ ”开头,那么就以绝对路径的方式查找模块名称,例如require(‘/home/byvoid/module’) 将 会 按照 优 先 级 依次 尝 试 加 载 、/home/byvoid/module.js、/home/byvoid/module.json 和 /home/byvoid/module.node。
如果 require 参数以“./ ”或“../ ”开头,那么则以相对路径的方式来查找模块,这种方式在应用中是最常见的。例如前面的例子中我们用了require(‘./hello’)来加载同一文件夹下的hello.js。
其他加载
当 require 遇到一个既不是核心模块,又不是以路径形式表示的模块名称时,会试图在当前目录下的 node_modules 目录中来查找是不是有这样一个模块。如果没有找到,则会在当前目录的上一层中的node_modules 目录中继续查找,反复执行这一过程,直到遇到根目录为止。举个例子,我们要在 /home/byvoid/develop/foo.js 中使用 require(‘bar.js’) 命令,
Node.js会依次查找:
/home/byvoid/develop/node_modules/bar.js
/home/byvoid/node_modules/bar.js
/home/node_modules/bar.js
/node_modules/bar.js
相关文章推荐
- node-webkit-MusicBox 基于nwjs ,html5 ,制作的音乐盒子
- Nodejs实战心得之eventproxy模块控制并发
- 开发node桌面级应用工具:apk转化epub
- Nodejs - 如何用 eventproxy 模块控制并发
- Spritekit游戏开发之SKSpriteNode(精灵)二
- Spritekit游戏开发之SKSpriteNode(精灵)一
- 2.3 Delete Middle Node
- hlist_head/hlist_node
- 欢迎使用CSDN-markdown编辑器
- windows下安装nodejs及框架express
- 拿nodejs快速搭建简单Oauth认证和restful API server攻略
- nodeJs get post
- 前后端分离的思考与实践(六)
- 前后端分离的思考与实践(五)
- 前后端分离的思考与实践(四)
- 前后端分离的思考与实践(三)
- 前后端分离的思考与实践(二)
- 前后端分离的思考与实践(一)
- nodejs 安装 使用
- Creating a basic site with Node.js and Express