angular2 組件之間傳值及事件傳遞

簡介

angular2及以后的版本(包括angular4)都稱為angular胆绊。組件之間的傳值主要分為父子組件間傳值和兄弟組件傳值兩大類敢伸,其中父子組件傳值又分為父組件向子組件傳值和子組件向父組件傳值兩種。

一步淹、父組件向子組件傳值
1.1 示例一

父組件中把roleName傳給子組件使用


parent.ts
parent.html
child.ts
child.html

以上四步即完成了一個父組件向子組件傳值的操作霉祸。

1.2 示例二:攔截輸入屬性

子組件可以攔截輸入屬性的數(shù)據(jù)并進行相應(yīng)的處理乳乌,即使用setter攔截輸入屬性或ngOnChanges監(jiān)聽數(shù)據(jù)變化,這里僅示例setter的方式

child.ts
1.3 父組件通過局部變量獲取子組件引用

在父組件的模板中為子組件創(chuàng)建一個局部變量叙淌,這個父組件可以通過這個局部變量來獲得讀取子組件公共成員變量和函數(shù)的權(quán)限秤掌;模板局部變量的作用域范圍僅存在于定義該模板局部變量的子組件愁铺。

parent.ts
child.ts
1.4 父組件使用@ViewChild獲取子組件的引用

由于模板局部變量只能在模板中使用,而不能直接在父組件類中使用闻鉴,這有一定的局限性茵乱,這里介紹一種更優(yōu)雅的數(shù)據(jù)傳遞方式---@ViewChild。
當(dāng)父組件需要獲取子組件中變量或者方法的讀取權(quán)限時椒拗,可以通過@ViewChild注入的方式來實現(xiàn)似将,組件中ViewChild的作用是聲明對子組件元素的實例引用,它提供了一個參數(shù)來選擇將要引用的組件元素蚀苛,這個參數(shù)可以是一個類的實例在验,也可以是一個字符串,它們實現(xiàn)的功能一樣堵未,只是表現(xiàn)形式不同腋舌,具體如下:

  • 參數(shù)為類實例,表示父組件將綁定一個指令或者子組件實例渗蟹。
  • 參數(shù)為字符串類型块饺,表示將起到選擇器的作用,即相當(dāng)于在父組件中綁定一個模板局部變量雌芽,獲取到子組件的一份實例對象的引用授艰。

1.41 下面是第一種參數(shù)類型(其中ContactCollectComponent是子組件):

parent.ts
  • 1.42 當(dāng)參數(shù)為字符串時
    • 在父組件中引入ElementRef
      import { Component, OnInit, ElementRef } from '@angular/core';
    • 在父組件模版中自組件上加局部變量#xxxx
      <flex-search-bar-history #historysearch></flex-search-bar-history>
    • 在父組件類中如下操作
      @ViewChild('historysearch') historySearch: ElementRef;
    • 之后就可以在父組件中操作子組件的變量或方法類,比如
      this.historySearch['searchString'] = '';
二世落、子組件向父組件傳值
2.1 示例一

子組件的輸出屬性onCollect傳遞給父組件淮腾,當(dāng)父組件監(jiān)測到子組件的onCollect動作時就會執(zhí)行父組件中相應(yīng)的方法,下面案例中同時父組件也把detail傳給了子組件

child.ts
child.html
parent.html
parent.ts
2.2 示例二

子組件的聯(lián)系人id傳給父組件使用


child.html
child.ts
parent.html
parent.ts

父組件綁定的事件通過$event對象來訪問num(即payload)的數(shù)據(jù)屉佳。

2.3 在子組件中獲取父組件的引用
  • 已知父組件的類型
    這種情況可以直接通過在構(gòu)造函數(shù)中注入ParentComponent來獲取已知類型的父組件引用谷朝,示例代碼如下:
child.ts
  • 未知父組件的類型
    一個組件可能是多個組件的子組件,有時候無法直接知道父組件的類型武花,在Angular中圆凰,可通過“類-接口”的方式來查找,即讓父組件通過提供一個與“類-接口”標識同名的別名來協(xié)助查找体箕。
    首先創(chuàng)建Parent抽象類专钉,它只聲明了name屬性,沒有實現(xiàn)(賦值)累铅,示例代碼如下:
abstract

然后在ParentComponent組件的providers元數(shù)據(jù)中定義一個別名Provider驶沼,用useExisting來注入ParentComponent組件的實例,示例代碼如下:

parentComponent.ts

通過下面的代碼争群,在子組件中就可以通過Parent這個標識找到父組件的實例來回怜,示例代碼如下:

child.ts
三、兄弟組件間傳值

利用單例服務(wù)可組件間共享數(shù)據(jù):
@Injectable({ providedIn: 'root' })

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市玉雾,隨后出現(xiàn)的幾起案子翔试,更是在濱河造成了極大的恐慌,老刑警劉巖复旬,帶你破解...
    沈念sama閱讀 211,423評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件垦缅,死亡現(xiàn)場離奇詭異,居然都是意外死亡驹碍,警方通過查閱死者的電腦和手機壁涎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,147評論 2 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來志秃,“玉大人怔球,你說我怎么就攤上這事「』梗” “怎么了竟坛?”我有些...
    開封第一講書人閱讀 157,019評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長钧舌。 經(jīng)常有香客問我担汤,道長,這世上最難降的妖魔是什么洼冻? 我笑而不...
    開封第一講書人閱讀 56,443評論 1 283
  • 正文 為了忘掉前任崭歧,我火速辦了婚禮,結(jié)果婚禮上撞牢,老公的妹妹穿的比我還像新娘驾荣。我一直安慰自己,他們只是感情好普泡,可當(dāng)我...
    茶點故事閱讀 65,535評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著审编,像睡著了一般撼班。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上垒酬,一...
    開封第一講書人閱讀 49,798評論 1 290
  • 那天砰嘁,我揣著相機與錄音,去河邊找鬼勘究。 笑死矮湘,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的口糕。 我是一名探鬼主播缅阳,決...
    沈念sama閱讀 38,941評論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼景描!你這毒婦竟也來了十办?” 一聲冷哼從身側(cè)響起秀撇,我...
    開封第一講書人閱讀 37,704評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎向族,沒想到半個月后呵燕,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,152評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡件相,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,494評論 2 327
  • 正文 我和宋清朗相戀三年再扭,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片夜矗。...
    茶點故事閱讀 38,629評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡泛范,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出侯养,到底是詐尸還是另有隱情敦跌,我是刑警寧澤,帶...
    沈念sama閱讀 34,295評論 4 329
  • 正文 年R本政府宣布逛揩,位于F島的核電站柠傍,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏辩稽。R本人自食惡果不足惜惧笛,卻給世界環(huán)境...
    茶點故事閱讀 39,901評論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望逞泄。 院中可真熱鬧患整,春花似錦、人聲如沸喷众。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽到千。三九已至昌渤,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間憔四,已是汗流浹背膀息。 一陣腳步聲響...
    開封第一講書人閱讀 31,978評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留了赵,地道東北人潜支。 一個月前我還...
    沈念sama閱讀 46,333評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像柿汛,于是被迫代替她去往敵國和親冗酿。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,499評論 2 348

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)已烤,斷路器鸠窗,智...
    卡卡羅2017閱讀 134,629評論 18 139
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法胯究,內(nèi)部類的語法稍计,繼承相關(guān)的語法,異常的語法裕循,線程的語...
    子非魚_t_閱讀 31,598評論 18 399
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,761評論 25 707
  • 你相信聽到的臣嚣,還是看到的? 上個月剛換的工作剥哑,說是換也不是硅则,就是回到了之前的公司上班了。按照我的性格來說株婴,既然走了...
    事是拾閱讀 117評論 0 6
  • day 58 第一章 Here Comes Charlie Only once a year, on his bi...
    123逍遙游閱讀 454評論 0 1