package.json 依赖包约束及快速删除node_modules

文章目录

    • 一、package.json版本约束
      • 1、初始项目安装
      • [2. 已有 yarn.lock 文件的项目安装](#2. 已有 yarn.lock 文件的项目安装)
      • [3. 特殊情况](#3. 特殊情况)
        • [手动修改 package.json 版本:](#手动修改 package.json 版本:)
        • [使用 yarn upgrade 命令:](#使用 yarn upgrade 命令:)
    • 二、快速删除node_modules
    • [三、depcheck 检测npm未使用的依赖](#三、depcheck 检测npm未使用的依赖)

一、package.json版本约束

1、初始项目安装

当你第一次在项目中运行 yarn install 时(也就是项目里还没有 yarn.lock 文件),Yarn 会依据 package.json 文件里声明的依赖和版本范围来安装依赖。

json 复制代码
{
  "dependencies": {
    "lodash": "^4.17.21",
    "axios": "~0.21.1"
  }
}
  • ^ 符号:表示可以安装大于等于指定版本且小于下一个主版本的任意版本。例如 ^4.17.21 允许安装 4.x.x 版本中高于 4.17.21 的版本。
  • ~ 符号 :表示可以安装大于等于指定版本且小于下一个次版本的任意版本。例如 ~0.21.1 允许安装 0.21.x 版本中高于 0.21.1 的版本。
    在这种情况下,Yarn 会从 npm 注册表中选择符合 package.json 版本范围的最新版本进行安装。安装完成后,Yarn 会生成 yarn.lock 文件,记录实际安装的依赖版本。

2. 已有 yarn.lock 文件的项目安装

当项目中已经存在 yarn.lock 文件时,yarn.lock 文件会对依赖安装起到决定性作用。yarn.lock 文件详细记录了每个依赖的确切版本、下载地址和校验和等信息。

当你再次运行 yarn install 时,Yarn 会优先使用 yarn.lock 文件中记录的版本来安装依赖,而不是根据 package.json 中的版本范围去选择最新版本。这样做的目的是确保项目在不同环境下安装的依赖版本一致,避免因依赖版本不同而导致的兼容性问题。

3. 特殊情况

手动修改 package.json 版本:

如果你手动修改了 package.json 中依赖的版本范围,并且运行 yarn install,Yarn 会尝试在满足新的版本范围的前提下,尽量使 用 yarn.lock 中已有的版本。

如果没有合适的版本,Yarn 会根据新的版本范围去安装新的依赖,并更新 yarn.lock 文件。

使用 yarn upgrade 命令:

当你使用 yarn upgrade 命令时,Yarn 会根据 package.json 中的版本范围,尝试安装最新的符合条件的依赖版本,并更新 yarn.lock 文件。

综上所述,yarn install 时,在有 yarn.lock 文件的情况下,主要受 yarn.lock 文件影响;在没有 yarn.lock 文件时,则根据 package.json 的版本范围来安装。

二、快速删除node_modules

1、全局安装rimraf

json 复制代码
npm install -g rimraf          # 全局安装

2、快速删除node_modules,rimraf node_modules

json 复制代码
rimraf node_modules  # node_modules
rimraf node_modules package-lock.json  # 多目标删除
rimraf "**/.*"                         # 删除所有隐藏文件

3、与npm 脚本集成

json 复制代码
{
  "scripts": {
    "clear": "rimraf node_modules",
  }
}

执行脚本

json 复制代码
yarn clear 或  npm run clear

三、depcheck 检测npm未使用的依赖

全局安装

shell 复制代码
npm install -g depcheck

然后,在你的项目根目录下运行:

shell 复制代码
depcheck

注意:有些隐含依赖是必要的,所以这个只能参考,不能全部做为删除依赖的标准

相关推荐
轻口味2 天前
【每日学点HarmonyOS Next知识】获取资源问题、软键盘弹起、swiper更新、C给图片设置位图、读取本地Json
c语言·json·harmonyos·harmonyosnext
DarkLONGLOVE2 天前
一文读懂 XML 文档:概念、结构与应用场景!
前端·json
Newfocus!3 天前
GPU算力哪家好?GpuGeek推出高性能GPU云服务
json
故事里故去3 天前
.net 6.0 webapi支持 xml返回xml json返回json
xml·json·.net
Java陈序员5 天前
IDEA 必备插件!轻松搞定 JSON 格式化!
java·json·intellij idea
trabecula_hj5 天前
SpreadVue实现内置excel在线编辑并保存为后端可以接受的json格式
json·excel·spreadjs·spreadvue
阿珊和她的猫5 天前
SyntaxError: Invalid or unexpected token in JSON at position x
json·状态模式
Tipriest_6 天前
vscode user settings.json分享
ide·vscode·json
weixin_461769407 天前
将JSON格式数据转化为sql 插入语句
python·sql·json