
- Angular 教程
- Angular - 首頁
- Angular - 概述
- Angular - 特性
- Angular - 優點與缺點
- Angular 基礎
- Angular - 環境搭建
- Angular - 第一個應用
- Angular - MVC 架構
- Angular 元件
- Angular - 元件
- Angular - 元件生命週期
- Angular - 檢視封裝
- Angular - 元件互動
- Angular - 元件樣式
- Angular - 巢狀元件
- Angular - 內容投影
- Angular - 動態元件
- Angular - 元素
- Angular 模板
- Angular - 模板
- Angular - 文字插值
- Angular - 模板語句
- Angular - 模板中的變數
- Angular - SVG 作為模板
- Angular 資料繫結
- Angular - 資料繫結及型別
- Angular - 資料繫結
- Angular - 事件繫結
- Angular - 屬性繫結
- Angular - 屬性繫結
- Angular - 類和樣式繫結
- Angular 指令
- Angular - 指令
- Angular - 內建指令
- Angular 管道
- Angular - 管道
- Angular - 使用管道轉換資料
- Angular 依賴注入
- Angular - 依賴注入
- Angular HTTP 客戶端程式設計
- Angular - 服務
- Angular - HTTP 客戶端
- Angular - 請求
- Angular - 響應
- Angular - GET 請求
- Angular - PUT 請求
- Angular - DELETE 請求
- Angular - JSON-P
- Angular - 使用 HTTP 進行 CRUD 操作
- Angular 路由
- Angular - 路由
- Angular - 導航
- Angular - Angular Material
- Angular 動畫
- Angular - 動畫
- Angular 表單
- Angular - 表單
- Angular - 表單驗證
- Angular Service Workers & PWA
- Angular - Service Workers & PWA
- Angular 測試
- Angular - 測試概述
- Angular NgModules
- Angular - 模組介紹
- Angular 高階
- Angular - 身份驗證與授權
- Angular - 國際化
- Angular - 可訪問性
- Angular - Web Workers
- Angular - 伺服器端渲染
- Angular - Ivy 編譯器
- Angular - 使用 Bazel 構建
- Angular - 向後相容性
- Angular - 響應式程式設計
- Angular - 指令和元件之間的資料共享
- Angular 工具
- Angular - CLI
- Angular 其他
- Angular - 第三方控制元件
- Angular - 配置
- Angular - 資料顯示
- Angular - 裝飾器和元資料
- Angular - 基本示例
- Angular - 錯誤處理
- Angular - 測試和專案構建
- Angular - 生命週期鉤子
- Angular - 使用者輸入
- Angular - 新特性?
- Angular 有用資源
- Angular - 快速指南
- Angular - 有用資源
- Angular - 討論
Angular - 新特性?
Angular 社群不斷更新其版本。本章介紹 Angular 9 版本更新。
安裝 Angular 9
如果您想使用 Angular 9,首先需要使用以下命令設定 Angular 9 CLI
npm install -g @angular/cli@^9.0.0
執行此命令後,可以使用以下命令檢查版本
ng version
Angular 9 更新
讓我們簡要了解 Angular 9 更新。
Ivy 編譯器
Ivy 編譯器成為 Angular 9 中的預設編譯器。這使得應用執行速度更快,效率更高。而在 Angular 8 中,Ivy 是可選的。我們必須在 tsconfig.json 檔案中啟用它。
Ivy 編譯器支援以下特性:
更快的測試效能:TestBed 實現有助於更有效地進行測試。
改進的 CSS 類和樣式:Ivy 樣式易於合併和設計,更可預測。
改進的型別檢查:此特性有助於在開發過程中儘早發現錯誤。
增強的除錯功能:Ivy 提供了更多工具來啟用更好的除錯功能。這將有助於顯示有用的堆疊跟蹤,以便我們更容易跳轉到指令。
提前編譯 (Ahead-of-Time) 編譯器:這是編譯器效能的一個重要改進。AOT 構建速度更快。
改進的國際化:i18n 替換比以前的版本快十倍以上。
可靠的 ng update
ng update 非常可靠。它包含清晰的進度更新並執行所有遷移。可以使用以下命令完成:
ng update --create-commits
這裡:
–create-commits 標誌用於在每次遷移後提交程式碼。
改進的依賴注入
@Injectable 服務有助於在您的應用程式中添加註入器。providedIn 元資料提供了一個新的選項 platform,以確保該物件可被所有應用程式使用和共享。定義如下:
@Injectable({ providedIn: 'platform' }) class MyService {...}
TypeScript 3.8
Angular 9 設計為支援 3.8 版本。TypeScript 3.8 帶來了對以下特性的支援:
- 僅型別匯入和匯出。
- ECMAScript 私有欄位。
- 頂層 await。
- JSDoc 屬性修飾符。
- export * as ns 語法。
Angular 9.0.0-next.5
Angular 9.0.0-next.5 版本的 main.js 檔案大小更小,與之前的 Angular 8 版本相比,效能更好。
IDE 增強
Angular 9 提供了改進的 IDE 支援。TextMate 語法支援內聯和外部模板中的語法高亮。
結論
Angular 是一個靈活、不斷改進、持續更新且可靠的框架。Angular 極大地簡化了 SPA 開發流程。透過在每個版本中提供新的特性,例如Angular Universal、漸進式 Web 應用、Web Workers、Bazel 構建、Ivy 編譯器等,Angular 將擁有長久的生命週期並獲得前端開發者的完全支援。