很多人看到 Angular 从2.4.x
版本之后直接跳到了Angular 4.0.0
beta 版本,为什么没有 Angular 3.x
呢?
先说一下 Angular 4 将于 2017年3月 发布. (/≧▽≦)/
原因很简单
原因并没有你想的那么复杂,一句话就能描述:
__Angular开始使用semver
语义化版本,并做了一次版本对齐__.
早在去年9月. Angular 团队就宣布将使用 Semantic Versioning 也就是SEMVER
.
语义化版本就像它的名字所说的一样,让每一个版本号的添加都有其意义. 这可以让开发人员迅速明白此次升级的变动情况,而且可以让第三方工具比如 NPM 可以更便捷更安全的进行操作.
一个语义版本包括三个数字
:
主版本号 | 次版本号 | 修订号 |
---|---|---|
破坏性变更 | 功能添加,无破坏性变更 | Bug修正,无破坏性变更 |
版本号递增规则如下:
先行版本号及版本编译信息可以加到“主版本号.次版本号.修订号”的后面,作为延伸.
那么这对Angular团队意味着什么呢? 就像每个不断发展的软件一样,总会发生一些破坏性的改变. 例如,现有应用程序报出了一个编译器错误,这些错误在以前的编译器版本中未被注意到,无论怎样这些错误将会在升级时破坏现有Angular应用程序,这都需要团队变更主版本号.
就像以前 Igor Minar 说的,即使只是将 Angular 的 TypeScript 依赖 从 v1.8 升级到 v2.1 或者 v2.2 然后编译 Angular 也会在技术上导致突破性的变化. 所以他们非常重视SEMVER.
破坏性的改变并不一定是痛苦的
一直追随Angular社区的人,绝对知道我在说什么.我们从Angular 1
升级到angular 2
时,绝对是一个彻底的改变,包含新的API和新的模式. 显而易见的是:最终Angular 2是一个完全的重写,即使有可用的升级选项.
而从版本2更改为版本4或5的改变将不会像从Angular 1那样. 它不会是一个完全的重写,它将只是一些核心库的更改,需要一个主要的SEMVER版本更改. 此外,将有适当的调整阶段,以允许开发人员调整其代码.
现在Google内部,Angular团队使用一个工具来处理自动升级,甚至包括破坏性变更. 不过这仍然需要更详细的计划和调整,但团队正在努力使这个工具具有更好的可用性,目前看最有可能的情况是在2017年为angular 5
释放出来.
Angular 就是 Angular
有人可能已经猜到了,"Angular 2" 也是一种阶段性称谓.总有一天,比如到了版本 4 或者 _5_,这种称谓将被废弃,我们将会开始只称呼它为 "Angular" 不带版本后缀.
同时,我们现在应该开始尽量避免使用 ng2-
或 angular2-
作为前缀的 GitHub/NPM库.
称谓说明
基本上从现在开始,命名所有版本的Angular简单地叫做“Angular”. 尽量避免使用版本号,除非真的有必要消除歧义.
比如:
默认使用“Angular”(“我是一个Angular开发者”,“这是一个Angular的聚会”,“Angular生态系统正在快速增长”)
“Angular 1”,“Angular 2”,“Angular 4”当谈到一个特定的发布版本时(例如,当谈到一个新引入的特性 - “这是一个介绍X特性X,介绍在Angular 4”从Angular 1到Angular 2“,”我为Angular 5提出这个更改“)
在报告错误时使用完整的semver版本(“此问题自Angular 2.3.1开始存在”)
所有文档(甚至包括Angular 1),将在未来几周内从AngularJS中删除“JS”.
在博客文章,课程,书籍中,或者当你定位一个非常特定的版本的Angular时,考虑添加一个标题行:
"这篇文章使用Angular v2.3.1"
这有助于避免别人感到困惑,特别是在撰写特定API时.
为什么没有 Angular 3 版本
核心Angular
库存在于一个单一的GitHub
存储库中,位于github.com/angular/angular
. 所有这些都以相同的方式进行版本化,但作为不同的NPM包分发:
包名 | 版本 |
---|---|
@angular/core | v2.3.0 |
@angular/compiler | v2.3.0 |
@angular/compiler-cli | v2.3.0 |
@angular/http | v2.3.0 |
@angular/router | v3.3.0 |
可以看到 @angular/router
的版本的当前未对齐. 由于router
包版本的这种不对齐,并且已经造成了一定的使用混乱. Angular 团队决定直接使用Angular v4
. 采用这种方式,将所有的核心包对齐,这将更容易维护并且帮助避免将来的混乱.
为什么router
已经到了 v3.x.x
?这是Angular团队发布 router v3 时的官方公告.
此外,重要的是要了解Angular如何在Google中使用和集成(Igor在这里的主题演讲中谈到这一点). 所有Google应用程序使用Angular版本等于当前GitHub的Angular仓库的主分支. 每当一个新的提交到达master,它将被整合到谷歌独立而庞大的mono-repo,其中还有其他产品,如地图,Adsense等. 因此,在Google内部使用Angular的所有项目套件都将针对此新版本运行其广泛的测试. 这使得团队非常有信心去裁剪一个新版本,因为它将包含已经在Google中进行过测试的Angular软件包的完全组合版本. 因此,具有对齐的版本是完全有道理的,并且随着时间的推移更容易维护它们,这反过来有助于团队在发布新特征方面更有成效.
暂定释放时间表
Angular 团队基于时间周期的发布策略,发生在三个周期:
补丁每周发布.
主要版本发布之后每月3次次要版本发布.
主要版本,每6个月更换一次,易于迁移.
2017年开始之后接下来的3个月将专心完成 Angular 4.0.0
.
总结
其实相关的也就那么几点: