package.json 中版本号遵循什么原则

package.json 中的 version 一般遵循 语义化版本(Semantic Versioning,SemVer) 规范。

规范官网:

Semantic Versioning 2.0.0

格式:

json 复制代码
{
  "version": "1.2.3"
}

对应:

复制代码
MAJOR.MINOR.PATCH
主版本号.次版本号.修订号

1. PATCH(修订号)

复制代码
1.0.0 → 1.0.1

适用于:

  • Bug 修复
  • 性能优化
  • 文档修改
  • 内部实现调整

且:

复制代码
不会影响现有使用方式
不会破坏兼容性

例如:

复制代码
1.0.0
↓
修复表格滚动异常
↓
1.0.1

2. MINOR(次版本号)

复制代码
1.0.0 → 1.1.0

适用于:

复制代码
新增功能
新增组件
新增 API
新增配置项

同时:

复制代码
向后兼容

例如你的组件库:

复制代码
1.0.0

新增:

xml 复制代码
<TfChart />

升级:

复制代码
1.1.0

老项目无需修改代码。


3. MAJOR(主版本号)

复制代码
1.0.0 → 2.0.0

适用于:

复制代码
破坏性变更
Breaking Change

例如:

原来:

ini 复制代码
<TfTable :data="data" />

改成:

ini 复制代码
<TfTable :rows="data" />

旧代码失效:

复制代码
1.x.x
↓
2.0.0

常见版本演进

复制代码
1.0.0
1.0.1
1.0.2
1.0.3

1.1.0
1.1.1
1.1.2

1.2.0

2.0.0

0.x.x 特殊规则

很多组件库初期:

json 复制代码
{
  "version": "0.1.0"
}

表示:

复制代码
开发阶段
API 可能随时变化
不保证稳定

例如:

复制代码
0.1.0
0.2.0
0.3.0

即使有 Breaking Change,也不一定升主版本。

很多开源项目都会经历:

复制代码
0.1.0
0.5.0
0.9.0
1.0.0

预发布版本

Alpha

复制代码
1.0.0-alpha.1

表示:

复制代码
内部开发版
功能未完成

Beta

matlab 复制代码
1.0.0-beta.1

表示:

复制代码
功能基本完成
开始测试

RC

复制代码
1.0.0-rc.1

表示:

sql 复制代码
Release Candidate
发布候选版

通常:

复制代码
1.0.0-rc.1
↓
1.0.0-rc.2
↓
1.0.0

npm 常用升级命令

修订版本:

复制代码
npm version patch

1.0.0 → 1.0.1

次版本:

复制代码
npm version minor

1.0.0 → 1.1.0

主版本:

复制代码
npm version major

1.2.3 → 2.0.0

相关推荐
用户81423861188412 小时前
CSS或JS实现逐帧动画方案
前端
光影少年2 小时前
react性能优化
前端·react.js·掘金·金石计划
深蓝电商API2 小时前
逆向工程入门:从Chrome DevTools到JS混淆还原
前端·javascript·chrome·爬虫·chrome devtools
石山岭2 小时前
# iOS 题库
前端
Zella折耳根2 小时前
从零解析终端小游戏开发:功能实现与核心编程知识点复盘
前端
Pikachu8032 小时前
我在早高峰地铁里对手机吼了几句,隔壁同事直接看傻了
前端·后端
半岛@少年2 小时前
Webpack在前端项目中究竟发挥什么作用?
前端·webpack·前端工程化
2501_940041743 小时前
企业官网与品牌落地页,能直接交付的前端题目
前端
小番茄夫斯基3 小时前
全球大模型的价格和能力排行汇总
前端·后端·架构