您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

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

2024/4/15 3:29:46发布19次查看
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();}
更多编程相关知识,请访问:编程视频!!
以上就是angular父子组件间怎么进行通信?父子传值的方式浅析的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product