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属性");
}

通过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获取子组件实例


childFn
@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);
}

子组件:

childSend
@Input() send: Function;
public childSend() {
    this.send();
}

看完上述内容,你们对Angular中父子组件间如何进行通信有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。


标题名称:Angular中父子组件间如何进行通信
浏览路径:http://pcwzsj.com/article/jsdjde.html

其他资讯