Angular2實(shí)現(xiàn)組件交互的方法分析
本文實(shí)例講述了Angular2實(shí)現(xiàn)組件交互的方法。分享給大家供大家參考,具體如下:
前言
在Angular開發(fā)中,我們經(jīng)常會涉及到組件之間的交互,比如會引用自己部門開發(fā)的組件
有時(shí)候,我們需要向引用的組件里面綁定一些數(shù)據(jù),或者我們需要引用的子組件輸出一些數(shù)據(jù)
這時(shí),我們就需要處理好組件之間的交互
組件交互的關(guān)鍵代碼
父組件綁定數(shù)據(jù)到子組件
子組件
<h3>{{hero.name}} says:</h3>
@Input() hero: Hero;
父組件
<hero-child [hero]="myhero" ></hero-child> myhero = "Mr.IQ";
這里子組件的@Input表示它需要hero這個(gè)實(shí)體,之后父組件引入子組件的時(shí)候,就得在子組件標(biāo)簽內(nèi)寫入hero,同時(shí)在自己的組件內(nèi)為hero賦值就實(shí)現(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方法向父組件傳遞一個(gè)boolean值,父組件引入子組件之后,通過把子組件的方法綁定到自己的方法上,就可以達(dá)到監(jiān)聽子組件的效果
setter截聽輸入屬性值的變化
子組件
<h3>"{{name}}"</h3>
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ù)進(jìn)行修改顯示
父組件與子組件通過本地變量互動
子組件
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>
子組件定義了變量和方法,父組件引用子組件標(biāo)簽之后,通過在標(biāo)簽建立本地變量來代表子組件,然后通過變量就可以實(shí)現(xiàn)訪問子組件的變量和方法
小結(jié)
組件交互是經(jīng)常用到的知識,需要熟練掌握
還有其它交互方式,比如生命周期、服務(wù),遇到了可以繼續(xù)深入研究
更多關(guān)于AngularJS相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《AngularJS指令操作技巧總結(jié)》、《AngularJS入門與進(jìn)階教程》及《AngularJS MVC架構(gòu)總結(jié)》
希望本文所述對大家AngularJS程序設(shè)計(jì)有所幫助。
相關(guān)文章
angular2實(shí)現(xiàn)統(tǒng)一的http請求頭方法
今天小編就為大家分享一篇angular2實(shí)現(xiàn)統(tǒng)一的http請求頭方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08
Angular 2.x學(xué)習(xí)教程之結(jié)構(gòu)指令詳解
結(jié)構(gòu)指令通過添加和刪除 DOM 元素來更改 DOM 布局。Angular 中兩個(gè)常見的結(jié)構(gòu)指令是 *ngIf 和 *ngFor,下面這篇文章主要給大家介紹了關(guān)于Angular 2.x結(jié)構(gòu)指令的相關(guān)資料,需要的朋友可以參考下。2017-05-05
Angular.js中window.onload(),$(document).ready()的寫法淺析
這篇文章主要介紹了Angular.js中window.onload(),$(document).ready()的寫法淺析,需要的朋友可以參考下2017-09-09
Angular.js與Bootstrap相結(jié)合實(shí)現(xiàn)表格分頁代碼
最近一直在學(xué)習(xí)angularjs相關(guān)知識,在學(xué)習(xí)過程中寫了一個(gè)小demo,下面把代碼思路分享給大家,感興趣的朋友一起學(xué)習(xí)2016-04-04
詳解AngularJS臟檢查機(jī)制及$timeout的妙用
本篇文章主要介紹了詳解AngularJS臟檢查機(jī)制及$timeout的妙用,“臟檢查”是Angular中的核心機(jī)制之一,它是實(shí)現(xiàn)雙向綁定、MVVM模式的重要基礎(chǔ),有興趣的可以了解一下2017-06-06

