浅谈angular4生命周期钩子

网友投稿 461 2023-04-09


浅谈angular4生命周期钩子

理解

Angular提供了生命周期钩子,把这些关键生命时刻暴露出来,赋予我们在它们发生时采取行动的能力。可以将钩子函数理解为在合适的时候做合适的事情。

钩子函数

ng4主要提供了8个钩子函数:

1、ngOnchanges

@input属性(输入属性)发生变化时,会调用。非此属性,不会调用。

当输入属性为对象时,当对象的属性值发生变化时,不会调用,当对象的引用变化时会触发。

先于ngOnInit调用。

2、ngOnInit

只执行一次,dom操作可放在其中。(最常用)

3、NgDocheck

每次发生变更检测时会被调用

ngDoCheck() 是Angular中的变更检测机制.它由 zone.js 来实现的.其行为是只要你的Angularhttp://中的某个组件发生异步事件.就会检查整个组件树,以保证组件属性的变化或页面的变化是同步的.所以 ngDoCheck() 的触发相当频繁的.并且是我们无法预料到的.也许我们在页面上的一个无意识操作,就会触发几个甚至几十个的 ngDoCheck() 生命周期钩子.

4、ngAfterContentInit

在组件内容初始化之后调用

5、ngAfterContentChecked

内容投影:父组件写在子标签之间的内容会被渲染到子模板的ng-content中去,类似vue的slot

组件及子组件每次检查内容时调用

当父子组件都有该钩子时,父组件先执行。

6、ngAfterViewInthttp://

组件相应的视图初始化之后调用

7、ngAfterViewChecked

组件及子组件每次检查视图时调用

当父子组件都有该钩子时,子组件先执行。

ngAfterViewChecked与ngAfterViewInt中不允许修改绑定的属性(@input属性),否则抛出异常

8、ngOnDestory

销毁,事件解绑。

3.执行顺序

父组件:

组件模板

{{name}}

组件

@Component({

selector: 'father',

templateUrl: './father.component.html',

styleUrls: ['./father.component.scss']

})

export class FatherComponent implements OnInit {

public name:string;

constructor() { }

ngOnInit() {

console.log("父组件ngOninit");

}

ngOnchanges(){

console.log("父组件ngonchanges");

}

ngDoCheck (){

console.log("父组件ngDocheck")

}

ngAfterContentInit(){

console.log("父组件ngAfterContentInit")

}

ngAfterContentChecked(){

console.log("父组件ngAfterContentChecked")

}

ngAfterViewInit(){

console.log("父组件ngAfterViewInit")

}

ngAfterViewChecked(){

console.log("父组件ngAfterViewChecked")

}

}

子组件

@Component({

selector: 'son',

templateUrl: './son.component.html',

styleUrls: ['./son.component.scss']

})

export chttp://lass SonComponent implements OnInit {

@Input() name:string;

constructor() { }

ngOnInit() {

console.log("子组件ngOninit");

}

ngOnChanges (){

console.log("子组件ngonchanges");

}

ngDoCheck (){

console.log("子组件ngDocheck")

}

ngAfterContentInit(){

console.log("子组件ngAfterContentInit")

}

ngAfterContentChecked(){

console.log("子组件ngAfterContentChecked")

}

ngAfterViewInit(){

console.log("子组件ngAfterViewInit")

}

ngAfterViewChecked(){

console.log("子组件ngAfterViewChecked")

}

}

看打印结果:

当在父组件的input中输入内容时,会打印如下结果:

看到有人说只有当使用内容投影时才会调用ngAfterConentChecked,当上面的里面的代码DgGOnQgF很显然是没用ng-content的,不知道该怎么解释这个ngAfterConentChecked。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Spring Boot学习入门之AOP处理请求详解
下一篇:java 单例模式(饿汉模式与懒汉模式)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~