首页前端开发其他前端知识Angula组件通讯和生命周期的知识怎么理解

Angula组件通讯和生命周期的知识怎么理解

时间2024-03-27 11:42:03发布访客分类其他前端知识浏览1487
导读:这篇文章主要给大家介绍“Angula组件通讯和生命周期的知识怎么理解”的相关知识,下文通过实际案例向大家展示操作过程,内容简单清晰,易于学习,有这方面学习需要的朋友可以参考,希望这篇“Angula组件通讯和生命周期的知识怎么理解”文章能对大...
这篇文章主要给大家介绍“Angula组件通讯和生命周期的知识怎么理解”的相关知识,下文通过实际案例向大家展示操作过程,内容简单清晰,易于学习,有这方面学习需要的朋友可以参考,希望这篇“Angula组件通讯和生命周期的知识怎么理解”文章能对大家有所帮助。


组件通讯

1、向组件内部传递数据

app-favorite [isFavorite]="true">
    /app-favorite>
// favorite.component.ts
import {
 Input }
     from '@angular/core';

export class FavoriteComponent {
    
    @Input() isFavorite: boolean = false;

}
    

注意:在属性的外面加 [] 表示绑定动态值,在组件内接收后是布尔类型,不加 [] 表示绑定普通值,在组件内接收后是字符串类型

app-favorite [is-Favorite]="true">
    /app-favorite>
import {
 Input }
     from '@angular/core';


export class FavoriteComponent {

  @Input("is-Favorite") isFavorite: boolean = false
}
    

2、组件向外部传递数据

需求:在子组件中通过点击按钮将数据传递给父组件

!-- 子组件模板 -->
    
button (click)="onClick()">
    click/button>
// 子组件类
import {
 EventEmitter, Output }
 from "@angular/core"

export class FavoriteComponent {

  @Output() change = new EventEmitter()
  onClick() {

    this.change.emit({
 name: "张三" }
)
  }

}
    
!-- 父组件模板 -->
    
app-favorite (change)="onChange($event)">
    /app-favorite>
// 父组件类
export class AppComponent {

  onChange(event: {
 name: string }
) {

    console.log(event)
  }

}

组件生命周期


1、挂载阶段

挂载阶段的生命周期函数只在挂载阶段执行一次,数据更新时不再执行。

1)、constructor

Angular 在实例化组件类时执行, 可以用来接收 Angular 注入的服务实例对象。

export class ChildComponent {

  constructor (private test: TestService) {

    console.log(this.test) // "test"
  }

}
    

2)、ngOnInit

在首次接收到输入属性值后执行,在此处可以执行请求操作。

app-child name="张三">
    /app-child>
export class ChildComponent implements OnInit {

  @Input("name") name: string = ""
  ngOnInit() {

    console.log(this.name) // "张三"
  }

}
    

3)、ngAfterContentInit

当内容投影初始渲染完成后调用。

app-child>
    
	div #box>
    Hello Angular/div>
    
/app-child>
export class ChildComponent implements AfterContentInit {
    
  @ContentChild("box") box: ElementRefHTMLDivElement>
 | undefined

  ngAfterContentInit() {
    
    console.log(this.box) // div>
    Hello Angular/div>

  }

}
    

4)、ngAfterViewInit

当组件视图渲染完成后调用。

!-- app-child 组件模板 -->
    
p #p>
    app-child works/p>
export class ChildComponent implements AfterViewInit {
    
  @ViewChild("p") p: ElementRefHTMLParagraphElement>
 | undefined
  ngAfterViewInit () {
    
    console.log(this.p) // p>
    app-child works/p>

  }

}
    

2、更新阶段

1)、ngOnChanges

  • 当输入属性值发生变化时执行,初始设置时也会执行一次,顺序优于 ngOnInit

  • 不论多少输入属性同时变化,钩子函数只会执行一次,变化的值会同时存储在参数中

  • 参数类型为 SimpleChanges,子属性类型为 SimpleChange

  • 对于基本数据类型来说, 只要值发生变化就可以被检测到

  • 对于引用数据类型来说, 可以检测从一个对象变成另一个对象, 但是检测不到同一个对象中属性值的变化,但是不影响组件模板更新数据。

基本数据类型值变化

app-child [name]="name" [age]="age">
    /app-child>
    
button (click)="change()">
    change/button>
export class AppComponent {
    
  name: string = "张三";

  age: number = 20
  change() {

    this.name = "李四"
    this.age = 30
  }

}
export class ChildComponent implements OnChanges {

  @Input("name") name: string = ""
  @Input("age") age: number = 0

  ngOnChanges(changes: SimpleChanges) {

    console.log("基本数据类型值变化可以被检测到")
  }

}
    

引用数据类型变化

app-child [person]="person">
    /app-child>
    
button (click)="change()">
    change/button>
export class AppComponent {

  person = {
 name: "张三", age: 20 }

  change() {

    this.person = {
 name: "李四", age: 30 }

  }

}
export class ChildComponent implements OnChanges {

  @Input("person") person = {
 name: "", age: 0 }


  ngOnChanges(changes: SimpleChanges) {

    console.log("对于引用数据类型, 只能检测到引用地址发生变化, 对象属性变化不能被检测到")
  }

}

2)、ngDoCheck:主要用于调试,只要输入属性发生变化,不论是基本数据类型还是引用数据类型还是引用数据类型中的属性变化,都会执行。

3)、ngAfterContentChecked:内容投影更新完成后执行。

4)、ngAfterViewChecked:组件视图更新完成后执行。

3、卸载阶段

1)、ngOnDestroy

当组件被销毁之前调用, 用于清理操作。

export class HomeComponent implements OnDestroy {

  ngOnDestroy() {

    console.log("组件被卸载")
  }

}
    

以上就是关于“Angula组件通讯和生命周期的知识怎么理解”的相关知识,感谢各位的阅读,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注网络,小编每天都会为大家更新不同的知识。

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: Angula组件通讯和生命周期的知识怎么理解
本文地址: https://pptw.com/jishu/654196.html
用java的方法怎么实现文件的上传和下载 java怎样使用正则表达式,如何进行数据匹配

游客 回复需填写必要信息