angular父子组件间怎么进行通信?本篇文章给大家介绍一下angular父子组件传值方式。

通过Input和Ouput传值
父组件:html和ts
public name: string = "jack";
public changeName(value: string) {
this.name = value;
}子组件:html和ts
{{name}}
import { Component, Input, EventEmitter, Output } from '@angular/core';
@Input() name: string;
@Output() changeName: EventEmitter = new EventEmitter();
public emit() {
this.changeName.emit("修改name属性");
} 【相关教程推荐:《angular教程》】
通过setter监听属性的变化
父组件同上,子组件:
private _name: string = "";
@Input()
public get name(): string {
return this._name;
}
public set name(value: string) {
this._name = value + "定义结构";
}通过ngOnChanges钩子函数监听输入属性的变化
ngOnChanges在监听多个属性的时候,要比setter的方式简便一些。
@Input() name: string;
ngOnChanges(changes: SimpleChanges): void {
(({name}) => {
console.log(name.currentValue,name.previousValue);
})(changes);
}父组件html中通过模板变量调用子组件的方法和属性。
模板变量获取了子组件的一个引用。 父组件:
子组件:
public childFn() {
console.log("通过模板变量调用子组件中的方法");
}父组件通过ViewChild获取子组件实例
@ViewChild("child") child: LiftcycleComponent;
public childFn(): void {
this.child.childFn();
}通过service进行通信
service:
import { Subject } from 'rxjs';
import { Injectable } from '@angular/core';
@Injectable({
providedIn: 'root'
})
export class CommunService {
constructor() {}
public commun = new Subject();
communSend() {
this.commun.next("send");
}
} 父组件:
constructor(private commun: CommunService) { }
public send(): void {
this.commun.communSend();
}子组件:
constructor(private commun: CommunService) {
this.commun.commun.subscribe((value) => {console.log(value)});
}父组件传递方法
父组件通过属性传递给子组件方法,子组件进行调用,一般不推荐,React采用这种通信方式。 可能是基于this的绑定错综复杂,所以angular不太推荐。React Hooks的出现也有一部分原因 是class类的this错综复杂。 父组件:
public name: string = "jack";
public send(): void {
console.log(this.name);
}子组件:
@Input() send: Function;
public childSend() {
this.send();
}更多编程相关知识,请访问:编程视频!!










