这篇文章主要介绍“nodejs导入模块的方法以及require模块的执行过程”,在日常操作中,相信很多人在nodejs导入模块的方法以及require模块的执行过程问题上存在疑惑,小编查阅了各式资料,整理出
这篇文章主要介绍“nodejs导入模块的方法以及require模块的执行过程”,在日常操作中,相信很多人在nodejs导入模块的方法以及require模块的执行过程问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”nodejs导入模块的方法以及require模块的执行过程”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
最近在看node,所以就特意了解了下,它模块引入的过程。今天做个回顾记录,希望对正在阅读的你也有所帮助
第三方模块 ,或者自己封装的npm包放私库或者公库上(npm 上 通过 npm install来安装使用的)
文件模块,项目内部文件,通过相对路径或者绝对路径的方法require使用
1、读取文件,进入require方法 return mod.require(path)
2、进入mod.require发现是 实质执行了Module.prototype.require,(这里的id就是一开始的path),嗯~ 怎么又调用了Module._load,木的事,我们继续走
3、进入Module._load(),Module._load(id, this, false)根据路径加载模块
以文件名作为 Module._cache 对象的键查询该文件是否已经被缓存,命中缓存的话,直接 exports
如果不存在缓存数组中,Module._resolveFilename解析文件路径 为绝对路径,再执着的去查一次缓存,命中缓存的话 exports
前两次的缓存查找排除了外部模块的,再判断是不是内置模块,是的话 就exports
走到这里真的说明这个模块真的没有缓存过,那就new 一个
4、new Module()进入,创建空对象this.exports = {}:也就是我们最终要的exports对象,(其他模块里引模块 此处不继续深入研究)
5、Module._cache[filename] 步骤3中解析的路径做key ,步骤4中创建的对象做值存入我们的缓存数组。keep Going!!
6、module.load(),进入该函数
Module._extensions[extension](this, filename)根据不同的后缀去调用不同的加载方法(这里用的是策略模式)
我这里命中的是.js,该方法里又用fs.readFileSync同步读取文件,然后作参数调用 module._compile(content, filename)
7、module._compile()进入 ,发现又将content作wrapSafe(filename, content, this)的参数执行
8、再进入wrapSafe()ps:我这里直接讲老版本的,执行比较好理解
先是调用了Module.wrap,进入该函数,node模块包装成了必包的样子(function (){ }),形成一个独立模块
然后将返回的包装过的字符串模块做vm.runInThisContext参数 执行该模块代码(和js中new Function一样的效果 可以让字符串变成js来执行),node自己的内置方法详情查阅node官方
9、到这里 一个模块的require过程就执行完了,用户就会默认拿到module.export的返回结果
读取文件
读取到文件以后给文件包装一个函数
函数格式function (exports,module,require,_dirname,filename){}
通过runThisContext将模块变成js语法进行调用
到此,关于“nodejs导入模块的方法以及require模块的执行过程”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!
--结束END--
本文标题: nodejs导入模块的方法以及require模块的执行过程
本文链接: https://lsjlt.com/news/65745.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0