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

相关推荐
IT_陈寒5 小时前
JavaScript项目实战经验分享
前端·人工智能·后端
用户47949283569156 小时前
6w star,GitHub 趋势第一的 Ponytail,这个agent插件到底在火什么
前端·后端
薛定喵的谔7 小时前
我开源了一个精致的 Next.js 博客模板:Skyplume
前端·前端框架·next.js
张龙6878 小时前
构建生产级 AI Agent:工具调用与记忆架构实战指南
前端
kyriewen9 小时前
2026 年了,还在用 Node.js?Bun 迁移实战:20 分钟搞定,附踩坑记录
前端·javascript·node.js
青山Coding10 小时前
Cesium应用(八):物体运动的实现思路
前端·cesium
用户416596736935510 小时前
Android WebView 加载 file:// 离线页面调试教程
android·前端
Asmewill10 小时前
curl命令学习笔记一
前端
我是一只快乐的小螃蟹10 小时前
1.2 ArrayList 源码解析
前端
星栈10 小时前
我用 Rust + Dioxus 做了个全栈跨平台笔记应用:再把新建、编辑和交付补上
前端·rust·前端框架