npm是如何处理多版本依赖的?

两种模式

nest模式

基本行为:

require/import时,向上递归查找依赖,直到全局node_modules结束。

特点:

每个包在自己内部管理依赖,结构清晰简单。

不足:

如果A包B包都依赖了axios,就会导致axiosA包B包node_modules中各安装一次,产生重复安装。

flat模式

基本模式:

require/import时,向上递归查找依赖,直到全局node_modules结束。

特点:

npm install时,npm会将axios这种被多个包依赖的包提升到项目根目录的node_modules中。减少重复安装。

不足:

重复安装只是被缓解了,没有完全解决。

为什么说flat模式并没有完全解决重复安装的问题?

考虑如下依赖关系:

如果对上图应用flat模式,我们会遇到一个问题:

npm遍历A包B包,发现公共依赖axios@1.0,决定将axios@1.0提升到项目根目录的node_modules中。

接下来遍历B包C包,发现也有公共依赖axios@2.0,但是根目录已经被axios@1.0占用了,所以只能放弃提升,也就又出现了nest模式的重复安装问题。

技术前沿拓展

前端开发,你的认知不能仅局限于技术内,需要发散思维了解技术圈的前沿知识。细心的人会发现,开发内部工具的过程中,大量的页面、场景、组件等在不断重复,这种重复造轮子的工作,浪费工程师的大量时间。

介绍一款程序员都应该知道的软件JNPF快速开发平台,很多人都尝试用过它,它是功能的集大成者,任何信息化系统都可以基于它开发出来。

这是一个基于 Java Boot/.Net Core 构建的简单、跨平台快速开发框架。前后端封装了上千个常用类,方便扩展;集成了代码生成器,支持前后端业务代码生成,实现快速开发,提升工作效率;框架集成了表单、报表、图表、大屏等各种常用的 Demo 方便直接使用;后端框架支持 Vue2、Vue3。如果你有闲暇时间,可以做个知识拓展。

看完本文如果觉得有用,记得点个赞支持,收藏起来说不定哪天就用上啦~

相关推荐
楚轩努力变强34 分钟前
前端工程化常见问题总结
开发语言·前端·javascript·vue.js·visual studio code
鱼樱前端36 分钟前
rust基础二(闭包)
前端·rust
菜鸟学Python44 分钟前
Python web框架王者 Django 5.0发布:20周年了!
前端·数据库·python·django·sqlite
前端开发爱好者1 小时前
只有 7 KB!前端圈疯传的 Vue3 转场动效神库!效果炸裂!
前端·javascript·vue.js
pe7er1 小时前
RESTful API 的规范性和接口安全性如何取舍
前端·后端
Fly-ping1 小时前
【前端】JavaScript文件压缩指南
开发语言·前端·javascript
未来之窗软件服务2 小时前
免费版酒店押金原路退回系统之【房费押金计算器】实践——仙盟创梦IDE
前端·javascript·css·仙盟创梦ide·东方仙盟·酒店押金系统
拾光拾趣录2 小时前
常见 HTTP 请求头:从“为什么接口返回乱码”说起
前端·http
阿华的代码王国2 小时前
【Android】卡片式布局 && 滚动容器ScrollView
android·xml·java·前端·后端·卡片布局·滚动容器
2025年一定要上岸3 小时前
【pytest高阶】源码的走读方法及插件hook
运维·前端·python·pytest