继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

node.js中模块加载机制

指甲盖
关注TA
已关注
手记 25
粉丝 2
获赞 41

一.模块查找规则:当模块拥有路径但没有后缀时

    我们先创建一个 modulefindRules 文件夹

1.require('./find.js');

require方法根据模块路径查找模块,如果是完整路径,直接引入模块

在 modulefindRules 文件夹中新建一个require.js 文件,再新建一个find.js 文件

require.js 文件中,写入

require('./find.js')

http://img3.sycdn.imooc.com/5ed4e83f0001780406350109.jpg

find.js 文件中写一个

console.log("modulefindRules文件夹下的find.js被引用了")

modulefindRules 文件夹下执行

node require.js

就可以看到

http://img4.sycdn.imooc.com/5ed4e91c0001a57107060040.jpg

2.require('./find');

  1.如果模块后缀省略,先找同名js文件:find.js,如果没有找到,再找同名js文件夹find

  2.如果找到了同名文件夹find,再找文件夹find中的index.js文件

  3.如果find文件夹中没有找到index.js文件,就会去当前文件夹find中的package.js文件中查找main选项中的入口文件

  4. 如果找指定的入口文件不存在或者没有指定入口文件就会报错,模块没有被找到

3.实践

3.1 我们把require.js文件夹中的引用语句改成

require('./find');

不带后缀名的,再去执行

node require.js

得出一样的结果,也就是说如果模块后缀省略,先找同名js文件:find.js

如果此时我们把  find.js  名字改成  find.js.text  试一下结果会是什么样呢?

http://img3.sycdn.imooc.com/5ed4eab10001273508230275.jpg

3.2 新建一个 find 文件夹,文件夹中新建一个 index.js 文件;在index.js文件夹中输出一句话

console.log('find文件夹下的index.js文件被执行了')

执行

node require.js

结果:http://img2.sycdn.imooc.com/5ed4f6e30001c1d506410036.jpg

所以:如果找到了同名文件夹find,再找文件夹find中的index.js文件

3.3 如果find文件夹中没有找到index.js文件,就会去当前文件夹find中的package.js文件中查找main选项中的入口文件

我们 cd 到find文件夹中,执行一下

npm init

生成package.js文件,一切都是默认的,默认情况下,main选项的入口文件是 index.js;我们把main选项中的值改成 main.js ,然后新建一个main.js文件,

http://img4.sycdn.imooc.com/5ed505380001940e09030292.jpg

http://img1.sycdn.imooc.com/5ed5048100019df906680085.jpg

3.4 如果找指定的入口文件不存在或者没有指定入口文件就会报错,模块没有被找到

3.4.1如果我们把main选项的值改成a.js,而此时find文件夹中没有a.js文件

http://img4.sycdn.imooc.com/5ed5057e0001eec908210279.jpg

3.4.2如果我们把package.json中的main选项删除,再执行 node require.js,也是找不到文件的

http://img3.sycdn.imooc.com/5ed5bcae0001d94c06590277.jpg

http://img2.sycdn.imooc.com/5ed5bcc0000176a908540278.jpg

二.模块查找规则:当模块没有路径且没有后缀时

  require('find');

  1.Node.js会假设它是系统模块

  2.Node.js会去node_modules文件夹中

  3.首先看是否有该名字的js文件

  4.再看是否有该名字的文件夹

  5.如果是文件夹看文件夹里是否有index.js

  6.如果没有index.js查看该文件夹中的package.json中的main选项确定模块入口文件

  7.如果找指定的入口文件不存在或者没有指定入口文件就会报错,模块没有被找到


当模块没有路径且没有后缀时,模块查找流程图

http://img3.mukewang.com/5ed619a100015a9a08511204.jpg

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP