require 方法的加载规则
- 优先从缓存中加载
- 核心模块
- 路径形式的模块
- 第三方模块
一、优先从缓存中加载
main.js:执行加载a.js模块
require('./a')
a.js:执行加载b.js模块,并输出a被加载了
require('./b') console.log('a.js 被加载了')
b.js:输出b被加载了
console.log('b.js 被加载了')
结果:
可以看出:main去加载a.js,然后a在去加载b.js过程中,并没有打印两次 a.js被加载,Node会直接从require.cache中根据传入的id,取出该对象的exports值,不会再次执行该模块代码。
二、核心模块
核心模块的本质也是文件,核心模块文件已经被编译到了二进制文件中了,我们只需要按照名字来加载就可以了。如:
- require(‘fs’)
- require(‘http’)
三、路径形式的模块
我们说的路径形式的模块,其实就是加载自己写的JS文件,有四种方式可以加载
var fooExports = require('./index') //相对路径,常用 var fooExports = require('../index') //相对路径,常用 var fooExports = require('/index') //根目录,不常用 var fooExports = require('D:/demo/index') //根目录,不常用
四、第三方模块
- 凡是用到第三方模块,都必须通过 npm 来下载
- 使用的时候就可以通过 require(‘包名’) 的方式来进行加载才可以使用
- 不可能有任何一个第三方包和核心模块的名字是一样的
既不是核心模块、也不是路径形式的模块,就是第三方模块。加载方式如下
以 var template = require(‘art-template’) 为例:
- 先找到当前文件所处目录中的 node_modules 目录
- 然后根据以下方式找到文件中的 main 属性
- main 属性中就记录了 art-template 的入口模块
- 然后加载使用这个第三方包,但是实际上最终加载的还是文件
- 如果 package.json 文件不存在或者 main 指定的入口模块是也没有
- 则 node 会自动找该目录下的 index.js,也就是说 index.js 会作为一个默认备选项
- 如果以上所有任何一个条件都不成立,则会进入上一级目录中的 node_modules 目录查找
- 如果上一级还没有,则继续往上上一级查找
- 如果直到当前磁盘根目录还找不到,最后报错: can not find module xxx
第三方模块寻找顺序: node_modules/art-template > package.json 文件 > main 属性 > index.js
到此这篇关于详解在node.js中require方法的加载规则的文章就介绍到这了,更多相关node.js require方法加载规则内容请搜索NICE源码以前的文章或继续浏览下面的相关文章希望大家以后多多支持NICE源码!