詳解Angular組件之中間人模式
一、中間人模式

該組件樹(shù)中除了組件1以外,每個(gè)組件都有一個(gè)父組件可以扮演中間人的角色。頂級(jí)的中間人是組件1,它可以使組件2,組件3,組件6之間互相通訊。依次類推,組件2是組件4和組件5的中間人。組件3是組件7和組件8的中間人。
中間人負(fù)責(zé)從一個(gè)組件接收數(shù)據(jù)并將其傳遞給另一個(gè)組件。
二、例子
股票報(bào)價(jià)組件為例,假設(shè)交易員在監(jiān)看著報(bào)價(jià)組件的價(jià)格,當(dāng)股票價(jià)格達(dá)到某一個(gè)值的時(shí)候,交易員會(huì)點(diǎn)一個(gè)購(gòu)買按鈕,來(lái)購(gòu)買股票。問(wèn)題:報(bào)價(jià)組件并不知道應(yīng)該如何下單來(lái)買股票,它只是用來(lái)監(jiān)控股票價(jià)格的。所以報(bào)價(jià)組件在這時(shí)應(yīng)該通知它的中間人【也就是APP組件】告訴它交易員要在某個(gè)價(jià)格購(gòu)買某只股票。中間人應(yīng)該知道哪個(gè)組件可以完成下單,并將股票代碼和當(dāng)前的價(jià)格傳給這個(gè)組件。
1、報(bào)價(jià)組件上加購(gòu)買按鈕
在報(bào)價(jià)組件上加一個(gè)按鈕,在股票到某個(gè)價(jià)格的時(shí)候交易員可以點(diǎn)擊按鈕在這個(gè)價(jià)格買這個(gè)股票。
<div>
我是報(bào)價(jià)組件
</div>
<div>
股票代碼是{{stockCode}},股票價(jià)格是{{price | number:"2.0-2"}}
</div>
<div>
<input type="button" value="立即購(gòu)買" (click)="$($event)">
</div>
@Output()
buy:EventEmitter<PriceQuote>=new EventEmitter();
buyStock(event){
this.buy.emit(new PriceQuote(this.stockCode,this.price));
}
2、父組件接收處理事件
父組件中去監(jiān)聽(tīng)buy事件,獲得當(dāng)前的購(gòu)買信息后
<app-price-quote (buy)="buyHandler($event)" ></app-price-quote>
buyHandler(event:PriceQuote){
this.priceQuote=event;
}
把報(bào)價(jià)信息通過(guò)屬性綁定傳給下單組件即可。
<app-order [priceQuote]="priceQuote"></app-order>
3、下單組件
下單組件有一個(gè)輸入屬性接收?qǐng)?bào)價(jià)并展示到頁(yè)面。
@Input() priceQuote:PriceQuote;
<div>
我是下單組件
</div>
<div>
買100手{{priceQuote.stockCode}}股票,買入價(jià)格是{{priceQuote.lastPrice | number:"2.2-2"}}
</div>
4、運(yùn)行結(jié)果
報(bào)價(jià)組件價(jià)格一直在變,點(diǎn)立即購(gòu)買就會(huì)按照當(dāng)前價(jià)格買入當(dāng)前股票,什么時(shí)候點(diǎn)按鈕什么時(shí)候就會(huì)更新。

好處:在報(bào)價(jià)組件里沒(méi)有任何和下單組件相關(guān)的代碼,報(bào)價(jià)組件甚至不知道下單組件的存在。報(bào)價(jià)組件只是發(fā)射購(gòu)買時(shí)候的股票代碼和股票價(jià)格。同樣在下單組件中也沒(méi)有任何和報(bào)價(jià)組件相關(guān)的東西。報(bào)價(jià)組件和下單組件在彼此不知道的情況下共同完成里股票下單的功能。組件高重用。
三、使用服務(wù)作為中間人
如果兩個(gè)組件沒(méi)有共同的父組件,甚至不在一塊顯示,要通訊怎么辦?比如文章開(kāi)頭圖中的組件4和組件6。
這時(shí),應(yīng)該使用一個(gè)可注入的服務(wù)作為中間人。無(wú)論何時(shí)當(dāng)組件被創(chuàng)建,中間人服務(wù)會(huì)被注入。組件可以訂閱服務(wù)發(fā)射的事件流。
在使用Angular開(kāi)發(fā)一個(gè)應(yīng)用前,應(yīng)該深入思考并設(shè)計(jì)好編寫哪些可重用的組件,比如訂單組件,報(bào)價(jià)組件,哪些組件和服務(wù)做哪些組件的中間人。組件的輸入是什么,輸出是什么,組件之間如何通訊。然后開(kāi)始寫代碼。
以上就是詳解Angular組件之中間人模式的詳細(xì)內(nèi)容,更多關(guān)于Angular組件的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
AngularJS表格樣式簡(jiǎn)單設(shè)置方法示例
這篇文章主要介紹了AngularJS表格樣式簡(jiǎn)單設(shè)置方法,結(jié)合實(shí)例形式分析了AngularJS結(jié)合bootstrap針對(duì)表格樣式的相關(guān)設(shè)置技巧,需要的朋友可以參考下2017-03-03
Angular項(xiàng)目過(guò)大時(shí)的合理拆分angular?split
這篇文章主要為大家介紹了Angular項(xiàng)目過(guò)大時(shí)的合理拆分angular?split示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
AngularJS使用Filter自定義過(guò)濾器控制ng-repeat去除重復(fù)功能示例
這篇文章主要介紹了AngularJS使用Filter自定義過(guò)濾器控制ng-repeat去除重復(fù)功能,結(jié)合實(shí)例形式分析了AngularJS自定義過(guò)濾器的定義及數(shù)組過(guò)濾相關(guān)操作技巧,需要的朋友可以參考下2018-04-04
Angular通過(guò)指令動(dòng)態(tài)添加組件問(wèn)題
這篇文章主要介紹了Angular通過(guò)指令動(dòng)態(tài)添加組件問(wèn)題,文中通過(guò)寫一個(gè)小組件來(lái)簡(jiǎn)單總結(jié)下,需要的朋友可以參考下2018-07-07
angularjs實(shí)現(xiàn)分頁(yè)和搜索功能
這篇文章主要介紹了angularjs實(shí)現(xiàn)分頁(yè)和搜索功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
AngularJS實(shí)現(xiàn)的輸入框字?jǐn)?shù)限制提醒功能示例
這篇文章主要介紹了AngularJS實(shí)現(xiàn)的輸入框字?jǐn)?shù)限制提醒功能,涉及AngularJS事件監(jiān)聽(tīng)與元素屬性動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-10-10
詳解Angular Karma測(cè)試的持續(xù)集成實(shí)踐
這篇文章主要介紹了詳解Angular Karma測(cè)試的持續(xù)集成實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
AngularJS操作鍵值對(duì)象類似java的hashmap(填坑小結(jié))
我們知道java的hashmap中使用最多的是put(...),get(...)以及remove()方法,那么在angularJS中如何創(chuàng)造(使用)這樣一個(gè)對(duì)象呢?今天小編通過(guò)本文給大家分享下,感興趣的朋友一起學(xué)習(xí)吧2016-11-11

