如何避免 @types 软件包引入的问题,补丁级别增加会引入重大更改?

Posted

技术标签:

【中文标题】如何避免 @types 软件包引入的问题,补丁级别增加会引入重大更改?【英文标题】:How to avoid problems introduced by @types packages with patch level increase that introduces breaking change? 【发布时间】:2021-01-11 20:44:26 【问题描述】:

我意识到我们的 Angular 应用程序的 Jenkins 构建已损坏。我们收到以下错误消息。:

ERROR in node_modules/angular2-hotkeys/lib/hotkeys.service.d.ts:9:16 - error TS2304: Cannot find name 'MousetrapInstance'.

9     mousetrap: MousetrapInstance;
                 ~~~~~~~~~~~~~~~~~

那么问题就是@types/mousetrap中的following breaking change来自:

export const mousetrap: MousetrapInstance;

到:

export const mousetrap: Mousetrap.MousetrapInstance;

在angular2-hotkeyspackage.json中,依赖定义如下:

"dependencies": 
     "mousetrap": "^1.6.0",
     "@types/mousetrap": "^1.6.0"
 ,

避免这个版本问题的正确 NPM 方法是什么?

【问题讨论】:

可能有助于 angular2-hotkeys 并修复他们的 package.json 其实有 github.com/brtnshrdr/angular2-hotkeys/pull/135 ,但它仍然是开放的。但是您的问题仍然有效,也许有一种方法可以通过 npm 在本地覆盖依赖项 【参考方案1】:

您无法保证与package.json 一起使用的包版本,即使您指定了完全匹配(没有^),因为可能存在需要另一个版本的依赖项。

确保您计算机中的版本与 CI 中的版本相同的唯一方法是同时提交 package-lock.json 文件。

【讨论】:

以上是关于如何避免 @types 软件包引入的问题,补丁级别增加会引入重大更改?的主要内容,如果未能解决你的问题,请参考以下文章

js中如何避免动态引入重复资源

如何通过包括数据库补丁的 Elastic Beanstalk 部署避免停机?

什么叫Android程序安全补丁级别?

在 vc++ 中重新调整任何 clistctrl 列的大小时避免使用补丁

什么叫Android程序安全补丁级别?

如何避免嵌套订阅超过两个级别