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 被加载了')

结果:

详解在node.js中require方法的加载规则

可以看出: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

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。