本頁使用了標題或全文手工轉換

Angular

維基百科,自由的百科全書
跳至導覽 跳至搜尋
Angular
Angular full color logo.svg
開發者 Google
初始版本 2.0 / 2016年9月14日,​3年前​(2016-09-14[1]
穩定版本
8.2.13
(2019年10月30日,​3個月前​(2019-10-30[2]
預覽版本
9.0.0-next.15
(2019年10月30日,​3個月前​(2019-10-30[3]
源代碼庫 Angular 倉庫
編程語言 TypeScript
系統平台 Web 平台
類型 Web 應用框架
許可協議 MIT License
網站 angular.io

Angular (通常是指 "Angular 2+" 或 "Angular v2 及更高版本")[4][5] 是一個基於 TypeScript開源 Web 應用框架Google 的 Angular 團隊以及社區共同領導。Angular 是由 AngularJS 的同一個開發團隊完全重寫的。

Angular 和 AngularJS 之間的區別[編輯]

Angular 應用的架構。其主要的構造塊是模塊、組件、模板、元數據、數據綁定、指令、服務和依賴注入。

在設計上,Angular 是 AngularJS 的完全重寫。

  • Angular 沒有「作用域」或控制器的概念,其架構中的主要角色是一些層次化的組件。[6]
  • Angular 具有不同的表達式語法,主要是用 "[ ]" 來表示屬性綁定,以及用 "( )" 來表示事件綁定[7]
  • 模塊化 – 許多核心功能都已模塊化
  • Angular 建議使用 Microsoft 的 TypeScript 語言,該語言引入了如下特性:
  • TypeScriptECMAScript 6 (ES6) 的超集,並且與 ECMAScript 5 (即: JavaScript) 向下兼容
  • 動態加載
  • 異步模板編譯
  • RxJS 提供了迭代式回調。RxJS 在狀態可見性和調試方面有局限,不過可以使用諸如 ngReact 或 ngrx 之類的響應式第三方庫來解決這些問題
  • 支持 Angular Universal,它可以在服務器上運行 Angular 應用程序

歷史[編輯]

命名[編輯]

最初,團隊將這份 AngularJS 的重寫版本稱為 「Angular 2」,但這在開發人員之間引起了混亂。為了明確起見,該團隊宣布應該為這兩個框架分別使用各自的術語,其中 「AngularJS」 專指 1.X 版本,而不帶 「JS」 的 「Angular」 則專指版本2及更高版本。[8]

版本 2[編輯]

在2014年10月22~23日的 ng-Europe 會議上發布了Angular 2.0。[9][10] 2.0 版的重大變化在開發人員之間引起了很大爭議。[11] 2015年4月30日,Angular 開發組宣布 Angular 2 從 Alpha 推進到 Developer Preview。[12] Angular 2 於2015年12月推進至 Beta 版,[13] 並於 2016年5月發布了首個 rc 版本。[14] 其最終版本於2016年9月14日發布。

版本 4[編輯]

2016年12月13日發布了 Angular 4,它跳過了版本號 3,以免由於路由模塊的版本的未和其它模塊對齊而造成混淆(路由模塊在之前已經作為 v3.3.0 發布了)。[15] 其最終版本於2017年3月23日發布。[16] Angular 4 向後兼容 Angular2。[17]

Angular 4.3 版是次要版本,這意味着它沒有破壞性變更,是 4.xx 的直接替代品。

版本 4.3 中的特性

  • 引入了 HttpClient,這是一個更小、更易於使用且功能更強大的庫,可用於發起 HTTP 請求。
  • 一些新的路由器生命周期事件,用於追蹤守衛和解析過程。生命周期事件(比如 NavigationStart)集合中加入了四個新事件:GuardsCheckStart, GuardsCheckEnd, ResolveStart, ResolveEnd
  • 有條件的禁用動畫。

版本 5[編輯]

Angular 5 於2017年11月1日發布。[18] Angular 5 的主要改進包括對漸進式 Web 應用的支持、一個構建優化器,以及一些與 Material Design 相關的改進。[19]

版本 6[編輯]

Angular 6 於2018年5月4日發布[20]。這是一個主版本,其改進重點不在於底層框架,而在於工具鏈,其目的是讓工具鏈能在將來與 Angular 一起快速發展,改進點主要包括:ng update、ng add、Angular Elements、Angular Material + CDK 組件庫、Angular Material 初學者組件、CLI 工作空間、庫支持、服務提供商的搖樹優化、動畫性能改進,以及 RxJS v6。

版本 7[編輯]

Angular 7 於2018年10月18日發布。其升級主要集中在 Angular Material & CDK、虛擬滾動、選擇框在無障礙方面的改進、支持對符合 Web 標準的自定義元素進行內容投影,以及對 Typescript 3.1、RxJS 6.3、Node 10 (仍然支持 Node 8) 的依賴庫更新。[21]

版本 8[編輯]

Angular 8 於2019年5月28日發布。特性包括:為所有應用代碼進行差異化加載、針對惰性加載路由的動態導入、Web workers、支持 TypeScript 3.4,並且把 Angular Ivy 作為可選的預覽特性。Angular Ivy 的可選預覽特性包括:[22]

  • 生成的代碼在運行時更易於閱讀和調試
  • 更快的重新構建
  • 改進了有效載荷的大小
  • 改進了模板類型檢查
  • 向後兼容

未來的版本[編輯]

最值得期待的特性之一是 Ivy [22],它是一個向後兼容的、基於增量式 DOM 架構的全新渲染引擎。Ivy 從設計之初就考慮到了搖樹優化,這意味着應用的發布包中只會包含那些在應用中真正用到的 Angular 部件。

可以預期,每一個版本都會向後兼容前一個版本。Google 承諾每年會進行兩次升級。

支持政策與時間表[編輯]

所有主版本都提供了 18 個月的支持。其中包括 6 個月的活躍支持,在此期間會定期發布更新和補丁。然後是12個月的長期支持(LTS),在此期間只會發布關鍵修復程序和安全補丁。[23]

支持的 Angular 版本
版本 狀態 發布 活躍期結束 LTS 期結束
^8.0.0 活躍 2019-05-28 2019-11-28 2020-11-28
^7.0.0 LTS 2018-10-18 2019-04-18 2020-04-18
^6.0.0 LTS 2018-05-03 2018-11-03 2019-11-03

[編輯]

Angular Material[編輯]

Angular Material 是一個 UI 組件庫,它在 Angular 中實現了 Material Design[24][25][26][27]

另請參閱[編輯]

參考資料[編輯]

  1. ^ Angular, version 2: proprioception-reinforcement. blogspot.com. September 14, 2016 [2017-03-18]. 
  2. ^ GitHub - angular/angular: One framework. Mobile & desktop.. 31 December 2018 –通過GitHub. 
  3. ^ angular/CHANGELOG.md at master · angular/angular. GitHub. [2019-10-19]. 
  4. ^ r/Angular2. reddit. 
  5. ^ AngularJS 與 Angular 2+: 一份詳細的比較. 6 April 2018. 
  6. ^ Angular 文檔. angular.io. 
  7. ^ AngularJS 和 Angular 之間有什麼區別?. gorrion.io. September 19, 2017 [2018-01-28]. 
  8. ^ Angular: Branding Guidelines for AngularJS. [2017-03-04]. 
  9. ^ Coman Hamilton. A sneak peek at the radically new Angular 2.0. [2015-10-21]. 
  10. ^ Ng-Europe schedule. 
  11. ^ Coman Hamilton. Angular 2.0 announcement backfires. [2015-10-21]. 
  12. ^ @angularjs. Angular 2 moves from Alpha to Developer Preview! Dev guide and API docs now available at ... angular.io/docs/js/latest (推文). 30 Apr 2015 [2015-10-21] –通過Twitter. 
  13. ^ Angular: Angular 2 Beta. angularjs.blogspot.it. [2016-07-13]. 
  14. ^ angular/angular. GitHub. [2016-05-04]. 
  15. ^ Ok... let me explain: it's going to be Angular 4.0. angularjs.blogspot.kr. [2016-12-14]. 
  16. ^ Angular 4.0.0 Now Available. angularjs.blogspot.ca. [2017-03-23]. 
  17. ^ Angular 4 coming in 2017, to be backwards compatible with Angular 2. react-etc.net. [2016-12-14]. 
  18. ^ Fluin, Stephen. Version 5.0.0 of Angular Now Available. [2 November 2017]. 
  19. ^ Angular 5 JavaScript framework delayed. 
  20. ^ Version 6.0.0 of Angular Now Available. [4 May 2018]. 
  21. ^ Fluin, Stephen. Version 7 of Angular — CLI Prompts, Virtual Scroll, Drag and Drop and more. Angular Blog. 2018-10-18 [2019-06-07]. 
  22. ^ 22.0 22.1 Fluin, Stephen. A plan for version 8.0 and Ivy. Angular Blog. 2019-02-08 [2019-06-07]. 
  23. ^ Angular. angular.io. [2019-06-07]. 
  24. ^ Noring, Christoffer; Deeleman, Pablo. Learning Angular: A no-nonsense guide to building real-world apps with Angular 5. Packt Publishing Ltd. 2017-12-08: 315. ISBN 9781787125940 (英語). 
  25. ^ Hajian, Majid. Progressive Web Apps with Angular: Create Responsive, Fast and Reliable PWAs Using Angular. Apress. 2019-05-22: 30. ISBN 9781484244487 (英語). 
  26. ^ Kasagoni, Shravan Kumar. Building Modern Web Applications Using Angular. Packt Publishing Ltd. 2017-05-29: 173. ISBN 9781785880032 (英語). 
  27. ^ Clow, Mark. Angular 5 Projects: Learn to Build Single Page Web Applications Using 70+ Projects. Apress. 2018-02-20: 245. ISBN 9781484232798 (英語). 

外部連結[編輯]