执行 node main.js 请问 b模块会被加载几次

//main.js
require('./a.js')
var fn = require('./b.js')
console.log(fn.say())
//a.js
console.log('a.js 被加载了')
var fn = require('./b')
//b.js
console.log('b.js 被加载了')
module.exports.say = function () {
console.log('我是b文件中的函数')
}

reuqire优先从缓存中去加载

在执行 main.js的时候,请问 b.js 文件会被加载几次?
有些小伙伴可能会说加载1次,有些小伙伴可能会说加载2次.
答案:只会加载 1次。
由于 b.js 在a.js文件中已经加载过一次了。
虽然在 main.js中虽然你引入了但是并不会再去加载。 因此:node加载模块的时候,优先从缓存中去加载模块。
这样做的目的是为了避免重复加载。 那在main.js中引入b模块有什么作用呢?
这样可以拿到其中的接口对象,但是不会重复执行里面的代码

node加载第三方模块的规则

通过 npm 下载的模块,使用 let xx= require('包名')来进行加载
当它加载的时候规则如下:
1.先找到当前文件所处目录中的 node_modules 目录,没有的话
2.然后去找node_modules/axios/package.json 文件
3.然后去找 node_modules/axios/package.json 文件中的 main 属性,
main属性中记录了axios的入口模块,然后加载使用这个第三方包。
4.如果 package.json 文件不存在或者 main 指定的入口模块是也没有的。
则 node 会自动找该目录下的 index.js文件进行加载,
也就是说 index.js 会作为一个默认备选项
5. 如果以上所有任何一个条件都不成立,则会进入上一级目录中的 node_modules 目录中去查找。
查找的时候会重复1-2-3-4。
6.如果上一级还没有,则继续往上上一级查找,查找的时候会重复1-2-3-4
7. 如果直到当前磁盘根目录还找不到,最后报错:
can not find module xxx
var axios= require('axios')

证明1-2-3步骤的正确性

证明1-2-3-4步骤的正确性

需要注意的是:
1.package.json 文件的书写规则,不能键名没有引号,需要注意一下
{
"main": ""
}

main这个选项的值如果你main的值写错了,默认加载 index.js

好消息

其实,在我们的项目中【有且只有】一个 node_modules,
放在项目根目录中,这样的话项目中所有的子目录中的代码都可以加载到第三方包
不会出现有多个 node_modules

node中的优先从缓存中加载模块与模块的加载规则的更多相关文章

  1. springboot中如何向redis缓存中存入数据

    package com.hope;import com.fasterxml.jackson.core.JsonProcessingException;import com.fasterxml.jack ...

  2. saiku显示不出新的cube(加载的cube,saiku会保存到缓存中,不重新加载)

    当用workbench 修改cube后,保存到saiku路径. saiku读取该cube时,如果以前加载过该cube(同路径,同名).则不会新加载,而是用缓存中的cube,这个cube是以前的cube ...

  3. Node.js——优先从缓存加载

    main中执行require操作,目的是获取接口对象,所以多次引用b,并不会重复执行模块内部的输入输出,因为缓存中已经存在

  4. linux中的优先搜索树的实现--prio_tree【转】

    转自:http://blog.csdn.net/bailyzheng/article/details/8041943 linux中的优先搜索树的实现--prio_tree prio_tree在linu ...

  5. Android中图片的三级缓存

    为什么要使用三级缓存 如今的 Android App 经常会需要网络交互,通过网络获取图片是再正常不过的事了 假如每次启动的时候都从网络拉取图片的话,势必会消耗很多流量.在当前的状况下,对于非wifi ...

  6. ASP.NET Core中使用EasyCaching作为缓存抽象层

    ⒈是什么? 和CacheManager差不多,两者的定位和功能都差不多. EasyCaching主要提供了下面的几个功能 统一的抽象缓存接口 多种常用的缓存Provider(InMemory,Redi ...

  7. 谈一谈SQL Server中的执行计划缓存(下)

    简介 在上篇文章中我们谈到了查询优化器和执行计划缓存的关系,以及其二者之间的冲突.本篇文章中,我们会主要阐述执行计划缓存常见的问题以及一些解决办法. 将执行缓存考虑在内时的流程 上篇文章中提到了查询优 ...

  8. 谈一谈SQL Server中的执行计划缓存(上)

    简介 我们平时所写的SQL语句本质只是获取数据的逻辑,而不是获取数据的物理路径.当我们写的SQL语句传到SQL Server的时候,查询分析器会将语句依次进行解析(Parse).绑定(Bind).查询 ...

  9. 关于缓存中Cookie,Session,Cache的使用

    文章来源:http://canann.iteye.com/blog/1941173 以前实现数据的缓存有很多种方法,有客户端的Cookie,有服务器端的Session和Application. 其中C ...

  10. android中图片的三级缓存cache策略(内存/文件/网络)

    实现图片缓存也不难,需要有相应的cache策略.这里我采用 内存-文件-网络 三层cache机制,其中内存缓存包括强引用缓存和软引用缓存(SoftReference),其实网络不算cache,这里姑且 ...

随机推荐

  1. 揭秘GES超大规模图计算引擎HyG:图切分

    摘要:GES大规模图计算引擎HyG通过实现不同的点边分区算法,可以灵活地供用户选择多种多样的切分策略,进而达到更好的运算性能. 本文分享自华为云社区<GES超大规模图计算引擎HyG揭秘之图切分& ...

  2. Go语言逆向技术:常量字符串

    摘要:Go语言源代码编译成二进制文件后,源代码中的字符串存放在哪里?是如何组织的? 本文分享自华为云社区<go语言逆向技术之---常量字符串解密>,作者:安全技术猿. Go语言源代码编译成 ...

  3. OpenSSF发布npm 最佳实践指南,应对开源依赖风险

    开源安全基金会(OpenSSF)发布了 npm 最佳实践指南,以帮助 JavaScript 和 TypeScript 开发人员降低使用开源依赖项相关的安全风险.OpenSSF Best Practic ...

  4. 火山引擎DataLeap:助力PICO落地数据流程规范,提升开发效率

    更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群   作为目前中国市场领跑的头部XR品牌之一,字节跳动旗下的PICO已经拥有了超百万客户.   过去一年,PICO在 ...

  5. Solon 框架,maven 单月下载量突破 200 万了!

    Solon 是什么开源项目? 一个,Java 新的生态型应用开发框架.它从零开始构建,有自己的标准规范与开放生态(历时五年,已有全球第二级别的生态规模).与其他框架相比,它解决了两个重要的痛点:启动慢 ...

  6. Solon 项目的单元测试插件

    1.引入依赖 <dependency> <groupId>org.noear</groupId> <artifactId>solon-test</ ...

  7. Windows 资源管理器 CPU100%

    Windows 资源管理器 CPU100% win + R打开运行框并输出:services.msc 点击确定打开服务:将服务中的Problem Reports Control Panel Suppo ...

  8. 二、swift添加存储策略

    系列导航 一.swift对象存储环境搭建 二.swift添加存储策略 三.swift大对象--动态大对象 四.swift大对象--静态态大对象 五.java操作swift对象存储(官网样例) 六.ja ...

  9. 二、Mycat安装

    系列导航 一.Mycat实战---为什么要用mycat 二.Mycat安装 三.mycat实验数据 四.mycat垂直分库 五.mycat水平分库 六.mycat全局自增 七.mycat-ER分片 万 ...

  10. 嵌入式Linux必读经典书籍(含下载方式)

    最近,在知乎看到一个问题,"嵌入式Linux有哪些好书推荐".我读研期间也喜欢收藏一些书籍,每次看到京东有活动,总是忍不住想买一些书籍回来. 随着时间越来越久,我买的书越来越多,但 ...