关于发布 npm 包镜像库,马上 pnpm 安装报未找到版本的问题?

关于发布 npm 包镜像库,马上 pnpm 安装报未找到版本的问题?

背景:我们在发布共有 npm 包时,npm 官方镜像发布成功,但是淘宝源下载却没有找到刚发布的版本,下面是我遇到问题心路历程

文章目录

  • [关于发布 npm 包镜像库,马上 pnpm 安装报未找到版本的问题?](#关于发布 npm 包镜像库,马上 pnpm 安装报未找到版本的问题?)
    • [发布 npm 包](#发布 npm 包)
    • [查询 npm 包](#查询 npm 包)
    • [pnpm 安装或更新包](#pnpm 安装或更新包)
    • 解决方法
    • 注意

发布 npm 包

js 复制代码
npm publish

发布 npm 包成功,此时我们发布的版本是 V0.0.50

查询 npm 包

js 复制代码
npm view [xxx_包名] versions

正常查询,成功查到版本

pnpm 安装或更新包

js 复制代码
pnpm update [xxx_包名]@0.0.50

此时报错了,报错信息告诉我们最新的版本是 0.0.49, 并没有你要更新的版本号的包,但是我们明明发布了最新,为什么会查不到

text 复制代码
PS E:\project> pnpm update @xxx/components@0.0.50
 ERR_PNPM_NO_MATCHING_VERSION  No matching version found for @xxx/components@0.0.50

This error happened while installing a direct dependency of E:\project

The latest release of @xxx/components is "0.0.49".

If you need the full list of all 47 published versions run "$ pnpm view @xxx/components versions".
Progress: resolved 38, reused 38, downloaded 0, added 0

原因:我们发布出去的包是到 npm 官方库,淘宝源的镜像库可能没有实时同步或者更新,我们可以通过以下命令查看,确实查不到刚发布的最新依赖包

js 复制代码
pnpm view [xxx_包名] version

解决方法

npmmirror 淘宝源镜像站

  1. 进去镜像站找到自己的依赖包,进去依赖包的详情页。
  2. 右下角的最近更新盒子,有一个进行同步按钮。
  3. 点击同步按钮等待同步完成,等待镜像站刷新出来即可安装成功。

示例:图下

  • 没有对应版本

  • 更新后展示出对应版本

注意

近期淘宝的 npm 镜像源证书过期,导致项目在装依赖的时候发生问题。

解决问题的办法,就是将旧的镜像源切换为新的镜像源。

js 复制代码
//查看当前源
npm config get registry
//删除源
npm config delete registry
//设置源
npm config set registry https://registry.npmmirror.com/

有疑问的同学可以私信我、对帮助到同学欢迎大家收藏评论。

相关推荐
sure2823 小时前
React Native中创建自定义渐变色
前端·react native
KKKK3 小时前
SSE(Server-Sent Events)流式传输原理和XStream实践
前端·javascript
子兮曰4 小时前
Humanizer-zh 实战:把 AI 初稿改成“能发布”的技术文章
前端·javascript·后端
Din4 小时前
主动取消的防抖
前端·javascript·typescript
百度地图汽车版4 小时前
【AI地图 Tech说】第九期:让智能体拥有记忆——打造千人千面的小度想想
前端·后端
臣妾没空4 小时前
Elpis 全栈框架:从构建到发布的完整实践总结
前端·后端
H5开发新纪元4 小时前
Nginx 部署 Vue3 项目完整指南
前端·javascript·面试
决斗小饼干4 小时前
跨语言移植手记:把 TypeScript 的 Codex SDK 请进 .NET 世界
前端·javascript·typescript
小码哥_常5 小时前
Android Intent.setAction失效报错排查与修复全方案
前端
bluceli5 小时前
JavaScript模块化深度解析:从CommonJS到ES Modules的演进之路
前端·javascript