搜尋
首頁web前端js教程一文帶你深入了解Angular11

本篇文章要跟大家介紹Angular11。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。

一文帶你深入了解Angular11

  Angular經歷了版本1.0到2.0的飛躍式發展,結合TypeScript這一強有力的工具,Angular正在成為大型前端的重要選項,本問主要介紹了Anguar 10的基本概念,透過對應程式碼,幫助讀者朋友們快速入手。 【相關推薦:《angular教學》】


一、Angular發展里程

  AngularJS原本是由Misko Hevery和Adam Abrons在2009年利用業餘時間開發的個人項目,最初的項目名稱叫做GetAngular,設計目標是讓Web設計師(非開發者)只使用HTML標籤來創建簡單的應用程式。隨著時間的推移,AngularJS演變成了一個全面的開發框架。 2010年,為了推動Google Feedback開發速度和專案的進展,Misko Hevery對基於GWT的Google Feedbac進行重構,將原來17000多行對程式碼壓縮到只有1500多行,從此Angularjs引起了重視,AngularJS轉變成Google的公司項目。

  Angular1.0引入了雙向資料綁定的概念。 2016年微軟和Google進行了合作,並採用TypeScript作為新的開發語言,發布了Angular2.0。 Angular2.0和Angularjs1.x是完全不同的架構,Angular2.0以後的版本統稱Angular2 。 Angular1.x的使用者群體也比較龐大,對應版本架構也持續維護,目前最新版本是1.8.2。 Angular2 的最新版本是11.0.0。

一文帶你深入了解Angular11

二、發展概況

#2.1 雙向資料綁定

  在常規的前端開發中,往往資料和視圖是透過單一項目綁定的方式進行關聯。這種模型的好處是結果相對簡單,model負責資料的更新,結合template進行渲染,view層只負責展示。這種結構的缺點是view層的資料變化無法回饋到model層,對於互動性較強的頁面無法滿足需求。這時候雙向資料綁定應運而生。

Column 1 Column 2
###################################圖1 單向數據綁定######圖2 雙向資料綁定############

2.2 核心特性變化

Angularjs雙向綁定方式—髒檢查

watch = {
    /**  当前的watch对象观测的数据名  **/
    name: ‘’,
    /** 得到新值 **/    
   getNewValue: function($scope) {
       ...
        return newValue;
    },
    /**  当数据发生改变时需要执行的操作  **/
    listener: function(newValue, oldValue) {
        ...
    }
}

任何原生的事件都不會觸發髒檢查,必須得呼叫<span class="katex--inline"><span class="katex"><span class="katex-html"><span class="base"><span class="mord mathdefault">s</span><span class="mord mathdefault">c</span><span class="mord mathdefault">o</span><span class="mord mathdefault">#p </span><span class="mord mathdefault">e</span><span class="mord">.</span></span></span></span></span>apply通知angular更新UI。

Angular雙向綁定方式—猴子補丁

function patchThen(Ctor: Function) {
      ...
      const originalThen = proto.then;
      proto[symbolThen] = originalThen;
      Ctor.prototype.then = function(onResolve: any, onReject: any) {
      		const wrapped = new ZoneAwarePromise((resolve, reject) => {
      			originalThen.call(this, resolve, reject);
      		});
      		return wrapped.then(onResolve, onReject);
      };
      ...
}

  Angular2 中有了Zone.js。原生隨便用,setTimeout,addEventListener、promise等都在ngZone中執行,angular並在ngZone中setup了對應的鉤子,通知angular2做對應的髒檢查處理,然後更新DOM。

三、基本概念

  • Module (模組)
  • Component(元件)
  • Template(範本)
  • Metadata(元資料)
  • Data Binding(資料綁定)
  • Directive(指令)
  • Service(服務)
  • Dependency Injection(依賴注入)

3.1 Module (模組)

  • 應用模組化
  • 模組是一個功能緊密的程式碼區塊,至少有一個根模組NgModule(AppModule)
// src/app/app.module.ts
import { NgModule }      from &#39;@angular/core&#39;;
import { BrowserModule } from &#39;@angular/platform-browser&#39;;
@NgModule({
 imports:      [ BrowserModule ],
 providers:    [ Logger ],
 declarations: [ AppComponent ],
 exports:      [ AppComponent ],
 bootstrap:    [ AppComponent ]
})
export class AppModule { }

3.2 Component(元件)

  • ##元件控制畫面上被稱為視圖的一小片區域
  • 在一個類別中定義元件的應用邏輯(主要用來支援視圖)。類別和視圖透過一個屬性和方法的API進行互動
  • 透過生命週期鉤子執行元件的建立、更新和銷毀
// src/app/hero-list.component.ts (class)
export class HeroListComponent implements OnInit {
 heroes: Hero[];
 selectedHero: Hero;

 constructor(private service: HeroService) { }

 ngOnInit() {
   this.heroes = this.service.getHeroes();
 }

 selectHero(hero: Hero) { this.selectedHero = hero; }
}
// src/app/hero-list.component.html
<li *ngFor="let hero of heroes" (click)="onSelect(hero)">

3.3 Template(模板)

  • 以HTML的形式告訴Angular如何渲染元件
  • HTML帶有Angular指令(NgClass、NgStyle、NgIf、NgFor…)
  • 自訂元件
  • // src/app/hero-list.component.html
    <h2 id="Hero-nbsp-List">Hero List</h2>
    
    <p><i>Pick a hero from the list</i></p>
    <ul>
     <li *ngFor="let hero of heroes" (click)="selectHero(hero)">
       {{hero.name}}
     </li>
    </ul>
    
    <app-hero-detail *ngIf="selectedHero" [hero]="selectedHero"></app-hero-detail>
  • 3.4 Metadata(元資料)

Metadata決定Angular的一個類別是元件

用TypeScript附加metadata的簡單方法是用修飾器
  • @Component函數接受配置物件並轉換為metadata
  • 模版、metadata和元件一起控制視圖
常用修飾器:@Injectable @Input @Output @RouterConfig
// src/app/hero-list.component.ts (metadata)

@Component({
 selector:    'app-hero-list',
 templateUrl: './hero-list.component.html',
 providers:  [ HeroService ]
})
export class HeroListComponent implements OnInit {
/* . . . */
}
範本、父子元件之間通訊
一文帶你深入了解Angular113.5 Data Binding(資料綁定) 一文帶你深入了解Angular11 #把資料值推送到HTML 控制項中,並將來自使用者的回應轉換成動作和對值的更新Column 2
###################雙向綁定的幾種形式######屬性綁定和事件綁定######模版嵌套############
// src/app/hero-list.component.html (binding)

<li>{{hero.name}}</li>
<app-hero-detail [hero]="selectedHero"></app-hero-detail>
<li (click)="selectHero(hero)"></li>

3.6 Directive(指令)

  • 带有@Directive() 装饰器的类,指示对DOM进行转换
  • 结构型指令和属性型指令
    结构型指令:通过添加、移除或者替换DOM元素来修改布局
// src/app/hero-list.component.html (structural)

<li *ngFor="let hero of heroes"></li>
<app-hero-detail *ngIf="selectedHero"></app-hero-detail>

属性型指令:修改现有元素的外观或行为

// src/app/hero-detail.component.html (ngModel)

<input [(ngModel)]="hero.name">

3.7 Service(服务)

  • 广义:包括应用所需的任何值、函数或特性,狭义:明确定义了用途的类
  • @Injectable() 装饰器来提供元数据
// src/app/logger.service.ts (class)

export class Logger {
   log(msg: any)   { console.log(msg); }
   error(msg: any) { console.error(msg); }
   warn(msg: any)  { console.warn(msg); }
}
// src/app/hero.service.ts (class)

export class HeroService {
 private heroes: Hero[] = [];

 constructor(
   private backend: BackendService,
   private logger: Logger) { }

 getHeroes() {
   this.backend.getAll(Hero).then( (heroes: Hero[]) => {
     this.logger.log(`Fetched ${heroes.length} heroes.`);
     this.heroes.push(...heroes); // fill cache
   });
   return this.heroes;
 }
}

3.8 Dependency Injection(依赖注入)

  • 为一个类的实例提供全部依赖的方法,大部分依赖是服务
  • 全应用级别注入器机制
  • 注入前必须注册一个提供者(Provider),然后返回服务类本身
    全局注册
@Injectable({
   providedIn: &#39;root&#39;,
})

特定注册

@NgModule({
   providers: [
      BackendService,
      Logger
    ],
    ...
})

注入

// src/app/hero-list.component.ts (component providers)

@Component({
   selector:    'app-hero-list',
   templateUrl: './hero-list.component.html',
   providers:  [ HeroService ]
})

四、创建第一Angular项目

4.1 基于Angular CLI

  • 安装Node.js 的当前版、活跃 LTS 版或维护期 LTS版
  • 安装Angular CLI
npm install -g @angular/cli
  • 创作工作空间和初始应用
npm new my-app
  • 运行应用
cd my-app
ng server --open

4.2 基于Angular Quickstart

  • 克隆Quickstart项目
git clone https://github.com/angular/quickstart.git my-app
  • 进入项目并安装依赖
cd ./my-app
npm run install
  • 启动项目
npm start

五、对比VUE

5.1 技术对比

主要点 Angular VUE
设计目标 全面的解决方案(浏览器端、服务端、客户端),基本包含了开发全流程 渐进增强,扩展性强,用户选择余地大
组件 组件是ng2+应用核心,支持Web Component标准,组件生命周期明确 完善的组件系统,可以从template生成或者render渲染,组件有明确的生命周期,使用virtual dom渲染
异步处理 原生支持RxJS,通过流模型处理异步任务 没有官方异步处理方案,可以用Promise,也可以用RxJS染
构建部署 支持Just In Time(JIT)和Ahead Of Time(AOT)模式,配合tree shaking可以大幅减少代码体积 配合Webpack打包工具,在不引入组件的情况下,体积更小
状态管理 ngrx vuex
安全 对不信值进行编码,避免XSS攻击,使用离线模版编译器,防止模版注入。官方http库防止XSRF 没有强制性阻止XSS攻击机制,输出HTML要注意配合v-html指令
优点 框架对几乎任何场景,都提供了标准化,更工程化,更适合大型项目多人协作面向新特性,发展空间大 框架可被不同程度的使用,可单独使用核心,也可加入状态管理,提供了更多选项。适合初期快速迭代,性能上没有很大缺陷
缺点 使用大量第三方库和组件,增加了潜在风险,应用性能可控性降低 由于提供了开发选项,多人协作下,对与使用程度和场景的处理可能不一样,随着项目增大,以快为特点的技术,在工程化和代码管理上可能存在困难。需要程序员手动实现类似依赖注入的功能、代码组织
选型 业务要求稳定、能够增量开发的项目 快速迭代、可以被替换的项目

5.2 开源组件库资源对比

Angular Vue
Angular Material2 Element UI
DEVUI Mint UI
PrimeNg iView UI
Kendo UI Bootstrap-Vue UI
Ng-lightning Ant Design Vue UI
Ng-bootstrap AT-UI UI
NG-ZORRO cube-ui UI
NGX Bootstrap Muse-UI UI

更多编程相关知识,请访问:编程视频!!

以上是一文帶你深入了解Angular11的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:csdn。如有侵權,請聯絡admin@php.cn刪除
JavaScript數據類型:瀏覽器和nodejs之間是否有區別?JavaScript數據類型:瀏覽器和nodejs之間是否有區別?May 14, 2025 am 12:15 AM

JavaScript核心數據類型在瀏覽器和Node.js中一致,但處理方式和額外類型有所不同。 1)全局對像在瀏覽器中為window,在Node.js中為global。 2)Node.js獨有Buffer對象,用於處理二進制數據。 3)性能和時間處理在兩者間也有差異,需根據環境調整代碼。

JavaScript評論:使用//和 / * * / * / * /JavaScript評論:使用//和 / * * / * / * /May 13, 2025 pm 03:49 PM

JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

Python vs. JavaScript:開發人員的比較分析Python vs. JavaScript:開發人員的比較分析May 09, 2025 am 12:22 AM

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

Python vs. JavaScript:選擇合適的工具Python vs. JavaScript:選擇合適的工具May 08, 2025 am 12:10 AM

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript:了解每個的優勢Python和JavaScript:了解每個的優勢May 06, 2025 am 12:15 AM

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

JavaScript的核心:它是在C還是C上構建的?JavaScript的核心:它是在C還是C上構建的?May 05, 2025 am 12:07 AM

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript應用程序:從前端到後端JavaScript應用程序:從前端到後端May 04, 2025 am 12:12 AM

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

Python vs. JavaScript:您應該學到哪種語言?Python vs. JavaScript:您應該學到哪種語言?May 03, 2025 am 12:10 AM

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境