[vscode]快速更新package.json里的依赖版本

本文介绍了如何使用VSCode快速更新`package.json`中的依赖版本,以及插件npm-dependency的安装和使用方法。同时提醒读者注意依赖版本更新的限制,如semver规则,以及当使用私有包源时的配置设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

vscode是个超级好用的开发工具,谁用谁知道。

不少前端开发者可能有和我一样的依赖保绿强迫症,简单说,就是见不得下面这些图标:

图片描述图片描述图片描述

但是手动一个个依赖检查么?不现实,也太累了。

npm update?那说明你还是太年轻了,看看它的说明吧:

This command will update all the packages listed to the latest version (specified by the tag config), respecting semver.

注意粗体部分,也就是说,npm update注定了不能帮你把依赖更新到“真正的”最新版,因为semver是有要求的。

譬如,你有一个依赖dep1,它的版本信息如下:

{
   "dist-tags": { "latest": "1.2.2" },
   "versions": [
     "1.2.2",
     "1.2.1",
     "1.2.0",
     "1.1.2",
     "1.1.1",
     "1.0.0",
     "0.4.1",
     "0.4.0",
     "0.2.0"
   ]
 }

然后,假设你的package.json里是这样写的:

"dependencies": {
   "dep1": "^1.1.1"
 }

那么npm update之后,它会变成"dep1": "^1.2.2",这很好,对不对?

但如果你的package.json里是这样写的:

"dependencies": {
   "dep1": "~1.1.1"
 }

那么npm update之后,它会变成"dep1": "^1.1.2",惊喜不惊喜?意外不意外?

如果不理解~^的区别,那你需要去看dependencies-semver

因为这个缘故,我想了想,可以写个插件解决问题。

安装

  1. 打开vscode

  2. 按下⌘ + P(windows下是ctrl + P),打开Command Palette

  3. 键入ext install vscode-npm-dependency找到npm-dependency插件

  4. 点击安装

使用

安装完毕后,选择一个你要更新的项目,并打开package.json文件,然后在打开的文档里,右键选择Npm update (latest),效果如下:

图片描述

你的package.json就这样被更新了。

注意事项

有朋友的依赖直接用了Git URL,那么这些依赖是会被忽略的,因为npm registry是拿不到这个包版本信息的。

有朋友用了自己部署的npm registry,例如,通过cnpm自己搭建了内部服务器,并且向其提交过私有包,那么显然从官方的https://registry.npmjs.org是不可能同步到你的私有包的,这就需要配置了,给你的vscode增加如下配置(可以是工作空间级别的,当然也可以是用户级别的):

{
    "npm.registry": "https://registry.npmjs.org/"
}

npm.registry的值,可以替换为:https://registry.npm.taobao.org等其他registry,然后就可以开心的更新了

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值