Npm 安装包出现一大堆 WARN??

一、问题

使用 npm 安装第三方包,有时会出现一大堆 WARN

image.png

二、分析

现在不管什么框架,vueumiwebpackbabeleslint 都讲究插件化开发,对普通开发人员提供插件书写接口方便自行扩展。想法是好的,但是存在一些问题。

eslint-config-react-app@2.1.0eslint的一个插件,写这个插件的时候 eslint 版本为 4.1.1。eslint 本身需要不断优化升级,版本更迭过程中会不停的新增 api、废弃 api。也就是说,eslint-config-react-app@2.1.0 肯定适用 eslint@4.1.1,但不一定适用 eslint@6.x(6.x 中可能会废弃相关api)。普通用户并不知道这一点,傻乎乎的下载最新的 eslinteslint-config-react-app 最新包,结果无法正常运行。

Npm 为了解决上面的问题,在 npm@1.2.10 之后提供了 peerDependencies 属性,具体使用如下,插件包 eslint-config-react-app 的 package.json 中添加该属性。

{
  // ....
  "peerDependencies": {
    "eslint": "^4.1.1"
  }
}

此时安装插件包 eslint-config-react-app,npm 会检测 node_modules 目录下有没有 eslint@4.x 的包,如果没有 npm 就会报警告⚠️ WARN,这样可以提示用户这里可能会有问题哦~不像之前运行报错而用户却完全无感。(在 npm@5.x 之前会直接报错 ERR,5.x 之后版本改为报警告)

peerDependencies 的出现一定程度上缓解了插件包依赖问题,但 未彻底解决问题。举例:eslint 版本的升级并不一定会大改 api,插件包eslint-config-react-appeslint6.x 也能正常运行,由于插件作者将 peerDependencies 写的太死(4.x),就会出现问题。你无法指望每个插件作者可以随时跟踪 eslint 主版本的变更,将包依赖问题丢给 来做在 dk 看来是最不靠谱的事。

webpack 相关插件都由官方维护,安装过程发现没有出现一行 WARN,很是清爽,那种各种引包造轮子的框架是无法避免这种隐患的。

三、解决

  • 升级相关依赖包,期待插件作者有更改依赖版本;
  • 去插件包的 github 提 pr,期待作者看到处理并发布新包;
  • 寻找符合条件的替代插件;
  • 无视它,尽管这是一个隐患,强迫症患者会被逼死。
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 用两张图告诉你,为什么你的 App 会卡顿? - Android - 掘金 Cover 有什么料? 从这篇文章中你...
    hw1212阅读 14,466评论 2 59
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,308评论 19 139
  • ESLint 配置 ESlint 被设计为完全可配置的,这意味着你可以关闭每一个规则而只运行基本语法验证,或混合和...
    静默虚空阅读 41,670评论 3 14
  • “学五渣”的美国大学申请术古典老师在《跃迁》中讲了一个传奇故事。一个国内的穷学生,平时不怎么努力,想要报考国外一个...
    淡之阅读 3,655评论 2 22
  • 那年, 萧瑟深秋,朗朗书声外, 窗外两人依墙而立, 校园微风吹拂, 阳光染落叶, 金色散满地, 白云躲猫猫, 天地...
    王龙果阅读 1,527评论 0 2