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

詳解Angular組件之生命周期(二)

 更新時間:2021年05月24日 09:14:25   作者:starof  
Angular本身監(jiān)督所有Angular組件和指令的生命周期 。為了在開發(fā)應用程序時順利進行,您必須了解結(jié)果的生命周期。組件是任何Angular應用程序的主要構(gòu)建塊。因此,必須了解它們才能理解組件生命周期的處理步驟。只有這樣才能在應用程序的開發(fā)中實現(xiàn)。

一、view鉤子

view鉤子有2個,ngAfterViewInit和ngAfterViewChecked鉤子。

1、實現(xiàn)ngAfterViewInit和ngAfterViewChecked鉤子時注意事項

以父組件調(diào)用子組件方法中例子為基礎,在父組件中實現(xiàn)ngAfterViewInit和ngAfterViewChecked鉤子。

這兩個鉤子是在組件的模版所有內(nèi)容組裝完成后,組件模版已經(jīng)呈現(xiàn)給用戶看了,之后這兩個鉤子方法會被調(diào)用。

@ViewChild('child1')
child1:Child1Component; //父組件中獲得子組件的引用

ngOnInit(){
  this.child1.greeting("Tom");
}

ngAfterViewInit(){
  console.log("父組件的視圖初始化完畢");
}

ngAfterViewChecked(){
  console.log("父組件的視圖變更檢測完畢");
}

在子組件中也實現(xiàn)這兩個鉤子

export class Child1Component implements OnInit,AfterViewInit,AfterViewChecked{

  constructor() { }

  ngOnInit() {
  }

  greeting(name: string) {
    console.log("hello" + name);
  }

  ngAfterViewInit(){
    console.log("子組件的視圖初始化完畢");
  }
  
  ngAfterViewChecked(){
    console.log("子組件的視圖變更檢測完畢");
  }
}

在父組件的ngOnInit中不直接調(diào)用子組件的greeting()方法,而是通過一個定時器每隔5s去調(diào)用一次。

ngOnInit(){
  setInterval(()=>{
    this.child1.greeting("Tom");
  },5000);
}

總結(jié):

1、Init先調(diào)用,checked后調(diào)用

看1中,首先子組件視圖初始化完畢,然后子組件視圖變更檢測完畢。

2、子組件先于父組件被組裝好

看2中,因為父組件中聲明了2個子組件,所以看到有2個子組件 初始化的動作。1號子組件初始化完畢,變更檢測完畢,2號子組件初始化完畢,變更檢測完畢后,父組件的初始化完畢才會被調(diào)用,然后父組件的變更檢測完畢才會被調(diào)用。

3、ngAfterViewInit只會在初始化完畢被調(diào)用一次。

4、定時器觸發(fā)方法后,兩個子組件的變更檢測會被調(diào)用,父組件的變更檢測也會被調(diào)用。

視圖沒有發(fā)生任何改變,變更檢測也會被調(diào)用,實現(xiàn)來ngAfterViewChecked()鉤子的方法都會被調(diào)用。

所以ngAfterViewChecked()鉤子一定要寫的精簡以免出現(xiàn)性能問題。

2、在一個變更檢測周期中禁止一個視圖被組裝好之后再去更新視圖

例子:

父組件

有一個message初始化為abc.顯示到模版上。

message:string='abc';

在父組件的ngAfterViewInit中更改message值。

ngAfterViewInit(){
  console.log("父組件的視圖初始化完畢");
  this.message="def";
}

會報錯。ngAfterViewInit()和ngAfterViewChecked()都是在視圖組裝完成后觸發(fā)的,所以在這兩個鉤子中更新組件中被綁定的屬性,觸發(fā)組件視圖的變化,Angular就會拋出異常。

解決辦法:

把代碼放在另一個時間循環(huán)里面。

ngAfterViewInit(){
  console.log("父組件的視圖初始化完畢");
  setTimeout(()=>{
    this.message="def";
  },0);
}

二、content鉤子

包括2個與投影相關(guān)的鉤子,ngAfterContentInit()和ngAfterContentChecked()鉤子。

ngAfterContentInit,ngAfterContentChecked和ngAfterViewInit,ngAfterViewChecked類似。

ngAfterViewInit,ngAfteViewChecked是在整個組件的視圖全部組裝完成后調(diào)用的。

ngAfterContentInit,ngAfterContentChecked是在被投影進來的內(nèi)容組裝完成后調(diào)用的。

1、Content鉤子的調(diào)用順序例子

父組件中實現(xiàn)ngAfterContentInit,ngAfterContentChecked和ngAfterContentInit()

export class AppComponent implements OnInit, AfterViewInit, AfterContentInit,AfterContentChecked{

ngAfterViewInit(){
  console.log("父組件的視圖初始化完畢");
}

ngAfterContentInit(){
  console.log("父組件投影內(nèi)容初始化完畢");
}
ngAfterContentChecked(){
  console.log("父組件投影內(nèi)容變更檢測完畢");
}

子組件中也實現(xiàn)這3個接口

export class Child2Component implements OnInit,AfterViewChecked,AfterContentInit,AfterContentChecked{

  constructor() { }

  ngOnInit() {
  }
  ngAfterViewInit(){
    console.log("子組件的視圖初始化完畢");
  }
  
  ngAfterContentInit(){
    console.log("子組件投影內(nèi)容初始化完畢");
  }
  ngAfterContentChecked(){
    console.log("子組件投影內(nèi)容變更檢測完畢");
  }
}

組裝視圖時,先組裝投影進來的內(nèi)容,然后組裝子組件中視圖的內(nèi)容,再加上父組件本身的內(nèi)容,然后才是父組件視圖初始化完畢。

2、Content鉤子中可以修改模版內(nèi)容

view鉤子里不能修改模版內(nèi)容,因為模版內(nèi)容組裝完畢后不能再修改里面內(nèi)容。但是Content鉤子里可以。

因為Content鉤子調(diào)用時整個視圖還沒有組裝完畢,只是投影進來的內(nèi)容被組裝完畢了。

父組件中在ngAfterContentInit鉤子里修改message信息不會報錯。

export class AppComponent implements OnInit, AfterViewInit, AfterContentInit,AfterContentChecked{
message:string='abc';
ngAfterViewInit(){
  console.log("父組件的視圖初始化完畢");
}

ngAfterContentInit(){
  console.log("父組件投影內(nèi)容初始化完畢");
  this.message='def';
}
ngAfterContentChecked(){
  console.log("父組件投影內(nèi)容變更檢測完畢");
}
ngOnInit(){

}

三、總結(jié)

上面四個方法在屬性初始化階段:構(gòu)造函數(shù)是初始化對象,ngOnChanges是初始化輸入屬性,ngOnInit是初始化除了輸入屬性以外其它的所有屬性,ngDoCheck是做一次變更檢查。

這四個方法執(zhí)行完整個組件所有屬性都被賦予了應該被賦的值。

組件開始渲染它的視圖,首先渲染投影進來的內(nèi)容,投影進來的內(nèi)容渲染完調(diào)用ngAfterContentInit和ngAfterContentChecked鉤子方法。

如果有子組件會調(diào)子組件創(chuàng)建的過程,子組件創(chuàng)建完或者沒有子組件,整個組件的視圖都初始化完畢了以后,會調(diào)ngAfterViewInit和ngAfterViewChecked鉤子方法。

至此,整個組件初始化完畢,組件會呈現(xiàn)給用戶交互。

用戶交互觸發(fā)Angular的變更檢測機制,檢測到發(fā)生了變更,在當前組件樹上所有活動組件上被實現(xiàn)的帶有check的鉤子方法都會被調(diào)用,用來檢查當前組件的變化,如果變化導致某個組件的輸入屬性也改變了,那個組件的ngOnChanges也會被調(diào)用。

組件在路由地址變化從而被銷毀的時候會調(diào)ngOnDestory()。

在ngOnDestory中銷毀一些引用的資源,比如反訂閱一個流,清除定時器之類的。

以上就是詳解Angular組件之生命周期(二)的詳細內(nèi)容,更多關(guān)于Angular的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評論