pnpm时代包版本不一致问题还是否存在

结论:不会有版本问题

问题描述:

假设我们有一个项目 MyApp,该项目依赖两个包 PackageA 和 PackageB(这两个包是直接依赖),这两个包又有相同的间接依赖:

  • PackageA 依赖 PackageC@v1.0.0
  • PackageB 依赖 PackageC@v1.0.1

先说为什么npm会存在这个问题:

npm下载依赖的策略是"包提升",所有的依赖,会直接下载到node_modules中,如果说出现同一个包不同版本的问题,会尝试下载一个中和版本,这样也就出现了版本问题。

pnpm为什么可以做到避免版本

这都是因为pnpm采用了"包隔离"的下载策略,看一下pnpm安装的依赖

可以看到,pnpm下载的第三方依赖文件夹下会有一个独立的node_modules目录,这样保证了每个第三方依赖,都有自己独立的依赖环境。

我们来创建一个项目验证这个问题

项目目录结构:

项目引用关系:

packageB --> packagec1.0.0

packageA --> packagec1.0.1

project

  • packageB

  • packageA

首先我将packageC发布到了npm上,包名:@caw-live/packagec 然后前后发布了两个版本:

  • 1.0.0 该包代码:

    js 复制代码
    index.js
    export const packageC = () => {
      console.log("packageC@v1.0.0");
    };
  • 1.0.1 该包代码:

    js 复制代码
    index.js
    export const packageC = () => {
      console.log("packageC@v1.1");
    };

然后packageA包和packageB包都使用pnpm安装packageC包

packageA下的代码:

js 复制代码
index.js
import { packageC } from "@caw-live/packagec";

export const packageA = () => {
  packageC();
};

packageB下的代码:

js 复制代码
index.js
import { packageC } from "@caw-live/packagec";

export const packageB = () => {
  packageC();
};

project项目使用pnpm link 安装 A和B包

project下的代码:

js 复制代码
import { packageA } from "packagea";
import { packageB } from "packageb";

packageA();
packageB(); 

运行一下:

打包测试生产环境 使用rollup进行打包

js 复制代码
import { nodeResolve } from '@rollup/plugin-node-resolve';

export default {
  input: 'index.js',
  output: [
    {
      file: 'dist/bundle.esm.js',
      format: 'es'
    },
  ],
  plugins: [
    nodeResolve({
      // 解析 node_modules 中的依赖
      preferBuiltins: false,
    }),
  ]
}; 

打包结果:

js 复制代码
const packageC$1 = () => {
  console.log("packageC@v1.0.1");
};

const packageA = () => {
  packageC$1();
};

const packageC = () => {
  console.log("packageC@v1.0.0");
};

const packageB = () => {
  packageC();
};

packageA();
packageB();

可以看到,1.0.0和1.0.1的代码,都被成功的打包进来了。

在给大家抛出一个问题,会的可以在评论区留言

package.json文件中记录的dependencies,devDependencies,是否会影响打包结果。

另外给朋友打个广告:

如果有想做学习基建ai项目的同学可以加v: CQ20190621

课程目录:

自研状态管理库(非redux,zustand,是自研)

基于antd组件库的二次开发

基于umi插件化基建工程

ai工作流项目

相关推荐
Raink老师21 小时前
用100道题拿下你的算法面试(矩阵篇-2):求转置矩阵
算法·面试·矩阵
Highcharts.js1 天前
Highcharts 云端渲染的真相:交互式图表与服务器端生成的边界
前端·信息可视化·服务器渲染·highcharts·图表渲染
zhuyan1081 天前
Linux 系统磁盘爆满导致无法启动修复指南
前端·chrome
编程牛马姐1 天前
独立站SEO流量增长:提高Google排名的优化方法
前端·javascript·网络
我叫黑大帅1 天前
通过eino-ext如何正常indexer RAG?
后端·面试·go
NotFound4861 天前
实战指南如何实现Java Web 拦截机制:Filter 与 Interceptor 深度分享
java·开发语言·前端
Dontla1 天前
高基数(High Cardinality)问题介绍(Prometheus、高基数字段、低基数字段)
前端·数据库·prometheus
whuhewei1 天前
为什么客户端不存在跨域问题
前端·安全
妮妮喔妮1 天前
supabase的webhook报错
开发语言·前端·javascript
yivifu1 天前
手搓HTML双行夹批效果
前端·html·html双行夹注