Angular父子组件间怎么进行通信?父子传值的方式浅析

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

通过Input和Ouput传值

父组件:html和ts

<app-liftcycle [name]=name (changeName)=changeName($event)></app-liftcycle>
public name: string = jack;
public changeName(value: string) {
    this.name = value;
}

子组件:html和ts

<div (click)=emit()>{{name}}</div>
import { Component, Input, EventEmitter, Output } from '@angular/core';
@Input() name: string;
@Output() changeName: EventEmitter<string> = new EventEmitter<string>();
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中通过模板变量调用子组件的方法和属性。

模板变量获取了子组件的一个引用。 父组件:

<app-liftcycle #child></app-liftcycle>
<button (click)=child.childFn()>按钮</button>

子组件:

public childFn() {
    console.log(通过模板变量调用子组件中的方法);
}

父组件通过ViewChild获取子组件实例

<app-liftcycle [name]=name (changeName)=changeName($event) #child></app-liftcycle>
<button (click)=childFn()>childFn</button>
@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<string>();
    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错综复杂。 父组件:

<app-liftcycle [send]=send.bind(this)></app-liftcycle>
public name: string = jack;
public send(): void {
    console.log(this.name);
}

子组件:

<button (click)=childSend()>childSend</button>
@Input() send: Function;
public childSend() {
    this.send();
}

更多编程相关知识,请访问:编程视频!!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


js中event的用法
js中能调用python吗
js中split的用法
js怎么设置边框样式
js中截取字符串的方法
js中innerhtml的用法
javascript的成熟分类方式有哪些
js中document是什么意思
js怎样让div中的文字居中
js中怎样定义一个对象
javascript的成熟分类介绍
js中parseint什么意思
js中字符串如何排序
void在js中是什么意思
js中如何定义函数
js中arguments是什么意思
js中什么是同步和异步
js中如何sleep一秒
js中ui函数是什么意思
js中如何遍历数组