首页前端开发JavaScriptAngular父子组件间怎么进行通信?父子传值的方式浅析

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

时间2024-01-30 03:56:03发布访客分类JavaScript浏览240
导读:收集整理的这篇文章主要介绍了Angular父子组件间怎么进行通信?父子传值的方式浅析,觉得挺不错的,现在分享给大家,也给大家做个参考。Angular父子组件间怎么进行通信?本篇文章给大家介绍一下Angular父子组件传值方式。通过Input...
收集整理的这篇文章主要介绍了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: EventEmitterstring>
     = new EventEmitterstring>
    ();
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 Subjectstring>
    ();
    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();
}
    

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

以上就是Angular父子组件间怎么进行通信?父子传值的方式浅析的详细内容,更多请关注其它相关文章!

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

Angular组件组件通信

若转载请注明出处: Angular父子组件间怎么进行通信?父子传值的方式浅析
本文地址: https://pptw.com/jishu/592008.html
如何给js创建一个数组对象 javascript如何删除数组首尾元素?

游客 回复需填写必要信息