欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Angular數(shù)據(jù)綁定及其實(shí)現(xiàn)方式

 更新時(shí)間:2021年05月17日 10:21:08   作者:華為云開(kāi)發(fā)者社區(qū)  
數(shù)據(jù)綁定是將應(yīng)用程序UI或用戶界面綁定到模型的機(jī)制。使用數(shù)據(jù)綁定,用戶將能夠使用瀏覽器來(lái)操縱網(wǎng)站上存在的元素。

前言

Web開(kāi)發(fā)需要模型和視圖之間的數(shù)據(jù)同步。這些模型基本上包含數(shù)據(jù)值,而視圖則處理用戶看到的內(nèi)容。因此,如果您想知道這在Angular中是如何發(fā)生的,這篇有關(guān)Angular數(shù)據(jù)綁定的文章將為您提供幫助。

下面提到的是此處討論的主題:

  • What is Data Binding?
  • Types of Data Binding in Angular
  • One-way Data Binding Interpolation Property Binding Event Binding
  • Two-way Data Binding

什么是數(shù)據(jù)綁定?

數(shù)據(jù)綁定是將應(yīng)用程序UI或用戶界面綁定到模型的機(jī)制。使用數(shù)據(jù)綁定,用戶將能夠使用瀏覽器來(lái)操縱網(wǎng)站上存在的元素。因此,無(wú)論何時(shí)更改了某些變量,該特定更改都必須反映在文檔對(duì)象模型或DOM中。

在Angular中,數(shù)據(jù)綁定定義了組件與DOM之間的交互。從AngularJS一直到最新的Angular 9版本,數(shù)據(jù)綁定是所有Angular版本的一部分。

Angular中的數(shù)據(jù)綁定類型

Angular允許單向和雙向數(shù)據(jù)綁定。單向數(shù)據(jù)綁定是一種簡(jiǎn)單的數(shù)據(jù)綁定類型,您可以在其中通過(guò)模型來(lái)操縱視圖。這意味著,對(duì)Typescript代碼進(jìn)行的更改將反映在相應(yīng)的HTML中。在Angular中,單向數(shù)據(jù)綁定是通過(guò)以下方式實(shí)現(xiàn)的:

  • Interpolation or String Interpolation
  • Property binding
  • Event binding

另一方面,雙向數(shù)據(jù)綁定允許以如下方式同步數(shù)據(jù):可以使用模型更新視圖,而可以使用視圖更新模型。這意味著您的應(yīng)用程序?qū)⒛軌蛟诮M件類及其模板之間共享信息。

單向數(shù)據(jù)綁定

在單向數(shù)據(jù)綁定中,數(shù)據(jù)僅沿一個(gè)方向流動(dòng),即從模型流向視圖。如前所述,Angular中的單向數(shù)據(jù)綁定可以為三種類型,即插值,屬性綁定和事件綁定。

Interpolation Binding

插值綁定用于從TypeScript代碼(即從組件到視圖)返回HTML輸出。在此,模板表達(dá)式在雙花括號(hào)內(nèi)指定。通過(guò)插值,可以將字符串添加到HTML元素標(biāo)簽之間以及屬性分配內(nèi)的文本中。這些字符串是使用Template表達(dá)式計(jì)算的。

例子:

<h1>{{title}}</h1>
 
Learn <b> {{course}}
</b> with Edureka.
 
2 * 2 = {{2 * 2}}
 
<div><img src="{{image}}"></div>

此代碼的Typescript部分如下:

export class AppComponent {
  title = 'Databinding';
  course ='Angular';
  image = 'paste the url here'
}

輸出:

component屬性在兩個(gè)花括號(hào)之間指定。Angular將用與該組件屬性關(guān)聯(lián)的字符串值替換該組件屬性。根據(jù)需要可以在不同的地方使用。角度將插值轉(zhuǎn)換為屬性綁定。

Angular還允許您配置插值定界符,并使用您選擇的內(nèi)容代替兩個(gè)花括號(hào)??梢允褂媒M件元數(shù)據(jù)中的插值選項(xiàng)來(lái)完成此操作。

模板表達(dá)式

模板表達(dá)式位于兩個(gè)大括號(hào)內(nèi),并且它們產(chǎn)生一個(gè)值。Angular將執(zhí)行該表達(dá)式,然后將特定的表達(dá)式分配給綁定目標(biāo)的屬性,例如HTML元素,組件或指令。

注意:插值括號(hào)之間的2 * 2是模板表達(dá)式。

屬性綁定

在“屬性綁定”中,值從組件的屬性流入目標(biāo)元素的屬性。因此,屬性綁定不能用于從目標(biāo)元素讀取或提取數(shù)據(jù)或調(diào)用屬于目標(biāo)元素的方法。元素引發(fā)的事件可以通過(guò)事件綁定進(jìn)行確認(rèn),事件綁定將在本文稍后介紹。

通常,可以說(shuō)將使用屬性綁定將組件屬性值設(shè)置為元素屬性。

例子:

<h1>Property binding</h1>
<div><img [src]="image"></div>

在上面的示例中,圖像元素的src屬性綁定到組件的圖像屬性。

Property binding and Interpolation

如果您已經(jīng)注意到,可以看到插值和屬性綁定可以互換使用??匆幌孪旅娼o出的示例對(duì):

<h2>Interpolation</h2>
 
<div><img src="{{image}}"></div>
 
<h2>Property binding</h2>
 
<div><img [src]="image"></div>

請(qǐng)注意,當(dāng)需要將元素屬性設(shè)置為非字符串?dāng)?shù)據(jù)值時(shí),必須使用屬性綁定而不是Interpolation。

事件綁定

使用事件綁定功能,您可以偵聽(tīng)某些事件,例如鼠標(biāo)移動(dòng),按鍵,點(diǎn)擊等。在Angular中,可以通過(guò)在等號(hào)(=)左側(cè)的常規(guī)方括號(hào)內(nèi)指定目標(biāo)事件名稱來(lái)實(shí)現(xiàn)事件綁定,以及右引號(hào)(“”)內(nèi)的模板語(yǔ)句。

例子:

<div>
  <button (click)="goBack()">Go back</button>
</div>

上例中的“ click ”是目標(biāo)事件的名稱,“ goBack()”是模板的語(yǔ)句。

輸出:

每當(dāng)發(fā)生事件綁定時(shí),Angular都會(huì)為目標(biāo)事件設(shè)置事件處理程序。當(dāng)該特定事件引發(fā)時(shí),模板語(yǔ)句由處理程序執(zhí)行。通常,接收者會(huì)涉及執(zhí)行響應(yīng)事件的操作的模板語(yǔ)句。在這里,binding用于傳達(dá)有關(guān)事件的信息。信息的這些數(shù)據(jù)值包括事件字符串,對(duì)象等。

Two-way Binding

Angular允許雙向數(shù)據(jù)綁定,這將允許您的應(yīng)用程序在兩個(gè)方向上共享數(shù)據(jù),即從組件到模板,反之亦然。這樣可以確保應(yīng)用程序中存在的模型和視圖始終保持同步。雙向數(shù)據(jù)綁定將執(zhí)行兩件事,即元素屬性的設(shè)置和偵聽(tīng)元素更改事件。

雙向綁定的語(yǔ)法為– [()}。如您所見(jiàn),它是屬性綁定語(yǔ)法(即[]和事件綁定語(yǔ)法())的組合。根據(jù)Angular的說(shuō)法,此語(yǔ)法類似于“盒子里的香蕉”。

例子:

<label ><b>Name:</b>
        <input [(ngModel)]="course.name" placeholder="name"/>
</label>

執(zhí)行此代碼時(shí),您將看到對(duì)模型或視圖的更改將導(dǎo)致對(duì)相應(yīng)視圖和模型的更改??匆幌孪旅娴膱D片,該圖片從視圖中將課程名稱從“ Python”更改為“ Pytho”:

以上就是詳解Angular數(shù)據(jù)綁定及其實(shí)現(xiàn)方式的詳細(xì)內(nèi)容,更多關(guān)于Angular數(shù)據(jù)綁定及其實(shí)現(xiàn)方式的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • AngularJS基礎(chǔ)學(xué)習(xí)筆記之簡(jiǎn)單介紹

    AngularJS基礎(chǔ)學(xué)習(xí)筆記之簡(jiǎn)單介紹

    AngularJS 不僅僅是一個(gè)類庫(kù),而是提供了一個(gè)完整的框架。它避免了您和多個(gè)類庫(kù)交互,需要熟悉多套接口的繁瑣工作。它由Google Chrome的開(kāi)發(fā)人員設(shè)計(jì),引領(lǐng)著下一代Web應(yīng)用開(kāi)發(fā)。也許我們5年或10年后不會(huì)使用AngularJS,但是它的設(shè)計(jì)精髓將會(huì)一直被沿用。
    2015-05-05
  • AngularJs基于角色的前端訪問(wèn)控制的實(shí)現(xiàn)

    AngularJs基于角色的前端訪問(wèn)控制的實(shí)現(xiàn)

    本篇文章主要介紹了AngularJs實(shí)現(xiàn)基于角色的前端訪問(wèn)控制,可以適用于不同的角色,有需要的可以了解一下。
    2016-11-11
  • Angularjs 1.3 中的$parse實(shí)例代碼

    Angularjs 1.3 中的$parse實(shí)例代碼

    本文通過(guò)實(shí)例代碼給大家介紹了angularjs $parse的相關(guān)知識(shí),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2017-09-09
  • AngularJS 中的指令實(shí)踐開(kāi)發(fā)指南(一)

    AngularJS 中的指令實(shí)踐開(kāi)發(fā)指南(一)

    指令(Directives)是所有AngularJS應(yīng)用最重要的部分。盡管AngularJS已經(jīng)提供了非常豐富的指令,但還是經(jīng)常需要?jiǎng)?chuàng)建應(yīng)用特定的指令。這篇教程會(huì)為你講述如何自定義指令,以及介紹如何在實(shí)際項(xiàng)目中使用
    2016-03-03
  • Angular的自定義指令以及實(shí)例

    Angular的自定義指令以及實(shí)例

    本文主要介紹了Angular的自定義指令,并提供了實(shí)例代碼,具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2016-12-12
  • AngularJS基礎(chǔ) ng-dblclick 指令用法

    AngularJS基礎(chǔ) ng-dblclick 指令用法

    本文主要介紹AngularJS ng-dblclick 指令,這里對(duì)ng-dblclick基礎(chǔ)資料整理并詳細(xì)介紹,簡(jiǎn)單的代碼實(shí)例和實(shí)現(xiàn)效果,希望能幫助學(xué)習(xí)AngularJS的朋友
    2016-08-08
  • 在Angular中實(shí)現(xiàn)懶加載的示例代碼

    在Angular中實(shí)現(xiàn)懶加載的示例代碼

    在Angular中,懶加載技術(shù)通過(guò)路由配置實(shí)現(xiàn)模塊的按需加載,可優(yōu)化應(yīng)用啟動(dòng)時(shí)間和減少初始加載代碼量,首先創(chuàng)建獨(dú)立模塊,在模板中使用<router-outlet>插入懶加載組件,并可采用預(yù)加載策略如PreloadAllModules,以提前加載所有懶加載模塊,優(yōu)化加載性能
    2024-10-10
  • Angular中$broadcast和$emit的使用方法詳解

    Angular中$broadcast和$emit的使用方法詳解

    本篇文章主要介紹了Angular中$broadcast和$emit的使用方法詳解,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • 詳解使用angularjs的ng-options時(shí)如何設(shè)置默認(rèn)值(初始值)

    詳解使用angularjs的ng-options時(shí)如何設(shè)置默認(rèn)值(初始值)

    本篇文章主要介紹了詳解使用angularjs的ng-options時(shí)如何設(shè)置默認(rèn)值(初始值),具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-07-07
  • AngularJS內(nèi)建服務(wù)$location及其功能詳解

    AngularJS內(nèi)建服務(wù)$location及其功能詳解

    這篇文章主要為大家詳細(xì)介紹了AngularJS內(nèi)建服務(wù)$location及$location功能,感興趣的小伙伴們可以參考一下
    2016-07-07

最新評(píng)論