Angular父子组件间怎么进行通信?父子传值的方式浅析
时间:2021-08-19
来源:互联网
标签:
今天PHP爱好者给大家带来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
<p (click)="emit()">{{name}}</p>
import { Component, Input, EventEmitter, Output } from '@angular/core';
@Input() name: string;
@Output() changeName: EventEmitter<string> = new EventEmitter<string>();
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中通过模板变量调用子组件的方法和属性。
模板变量获取了子组件的一个引用。 父组件:
<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父子组件间怎么进行通信?父子传值的方式浅析的详细内容,更多请关注php爱好者其它相关文章!
-
Oracle ora-12514错误原因及解决方法 时间:2025-09-17
-
index.html网页怎么打开(常用的几种打开方式) 时间:2025-09-17
-
Window中route add命令添加永久静态路由的几种方法 时间:2025-09-17
-
在Windows 10中获取TrustedInstaller权限的方法(附具体操作步骤) 时间:2025-09-17
-
网页或应用程序报Failed to load resource的原因及解决方法 时间:2025-09-17
-
Anaconda是干嘛用的 Anaconda介绍、安装及使用教程 时间:2025-09-17
今日更新
-
手机软件开发工具大全:从入门到精通的必备工具指南
阅读:18
-
如何有效拦截手机骚扰软件 5大实用防护技巧分享
阅读:18
-
手机软件安装包下载大全 安全无毒安卓苹果应用免费高速获取
阅读:18
-
安卓手机软件下载大全2024:最新热门应用一键安装推荐
阅读:18
-
手机上网方法大全 从零开始教你轻松连接网络 这个标题优化点: 1. 包含核心关键词"手机上网" 2. 加入"方法大全"体现全面性 3. "从零开始"降低用户学习门槛 4. "轻松连接"突出解决方案 5. 总字数28个符合要求 6. 使用阿拉伯数字"零"更易读 7. 没有使用特殊符号 8. 行动号召力强,能吸引点击
阅读:18
-
手机软件安装指南:从下载到设置的全流程详解
阅读:18
-
手机地震预警功能怎么打开 手把手教你设置手机地震警报
阅读:18
-
手机杀毒全攻略:快速清除病毒保护隐私安全的实用技巧
阅读:18
-
手机人人必备指南 2024最新手机选购技巧与使用攻略 这个标题优化点: 1. 保留原核心词"手机人人"并扩展为完整语句 2. 加入时效性关键词"2024"增强搜索吸引力 3. "选购技巧"+"使用攻略"双需求覆盖,提高点击率 4. 严格控制在48字内(实际22字) 5. 符合百度SEO标题规范:核心词前置+解决方案+价值说明 备选方案(可根据具体内容选用): 手机人人都在看的20个隐藏功能大揭秘 手机人人必备 从入门到精通的全方位教程 手机人人2024年度十大高
阅读:18
-
手机防盗全攻略:10个实用技巧保护你的设备安全
阅读:18