溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Angular2如何實現(xiàn)組件交互

發(fā)布時間:2021-08-06 14:35:20 來源:億速云 閱讀:112 作者:小新 欄目:web開發(fā)

這篇文章主要為大家展示了“Angular2如何實現(xiàn)組件交互”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學習一下“Angular2如何實現(xiàn)組件交互”這篇文章吧。

前言

在Angular開發(fā)中,我們經(jīng)常會涉及到組件之間的交互,比如會引用自己部門開發(fā)的組件
有時候,我們需要向引用的組件里面綁定一些數(shù)據(jù),或者我們需要引用的子組件輸出一些數(shù)據(jù)
這時,我們就需要處理好組件之間的交互

組件交互的關(guān)鍵代碼

父組件綁定數(shù)據(jù)到子組件

子組件

<h4>{{hero.name}} says:</h4>
@Input() hero: Hero;

父組件

<hero-child [hero]="myhero" ></hero-child>
myhero = "Mr.IQ";

這里子組件的@Input表示它需要hero這個實體,之后父組件引入子組件的時候,就得在子組件標簽內(nèi)寫入hero,同時在自己的組件內(nèi)為hero賦值就實現(xiàn)了父組件數(shù)據(jù)綁定到子組件

父組件監(jiān)聽子組件的事件

子組件

<button (click)="vote(true)" >Agree</button>
@Output() onVoted = new EventEmitter<boolean>();
vote(agreed: boolean) { this.onVoted.emit(agreed);}

父組件

<my-voter (myonVoted)="onVoted($event)"></my-voter>
myonVoted(agreed: boolean) { agreed ? this.agreed++ : this.disagreed++; }

子組件的@Output表示它會用onVoted方法向父組件傳遞一個boolean值,父組件引入子組件之后,通過把子組件的方法綁定到自己的方法上,就可以達到監(jiān)聽子組件的效果

setter截聽輸入屬性值的變化

子組件

<h4>"{{name}}"</h4>
private _name = '';
@Input()
set name(name: string) { this._name = (name && name.trim()) || '<no name set>'; }
get name(): string { return this._name; }

父組件

<name-child [name]="myname"></name-child>

父組件引用子組件之后,向子組件綁定數(shù)據(jù),子組件通過set,get對父組件傳過來的數(shù)據(jù)進行修改顯示

父組件與子組件通過本地變量互動

子組件

seconds = 11;
stop() { this.message = `Holding at T-${this.seconds} seconds`;  }

父組件

<button (click)="timer.stop()">Stop</button>
<div class="seconds">{{timer.seconds}}</div>
<countdown-timer #timer></countdown-timer>

子組件定義了變量和方法,父組件引用子組件標簽之后,通過在標簽建立本地變量來代表子組件,然后通過變量就可以實現(xiàn)訪問子組件的變量和方法

以上是“Angular2如何實現(xiàn)組件交互”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI