浅谈Angular组件之间通信的5种方法

angular组件间怎么通信?下面本篇文章给大家介绍一下angular组件之间通信的5种方法,有需要的可以参考~

浅谈Angular组件之间通信的5种方法

组件是angular的构建单元,在项目中为了保证组件之间的数据能够来回的传递,angular封装了一些能够实现组件之间通信的方法。【相关教程推荐:《angular教程》】

一、父组件通过输入型绑定将数据传递给子组件

父组件

parent.component.ts

age = 18;name = '  xiaoming '

登录后复制

parent.component.html


登录后复制登录后复制

子组件

child1.component.ts

@Input() age!: number;

登录后复制

截听输入属性值的变化

1、使用一个输入属性的 setter,以拦截父组件中值的变化,并采取行动。

child1.component.ts

@Input()set name(name: string) {    this._name = name.trim();}private _name: string;

登录后复制

2、使用 ngOnChanges()钩子函数来监测输入属性值的变化并做出回应。当需要监视多个、交互式输入属性的时候,本方法比用属性的 setter 更合适。

child1.component.ts

ngOnChanges(changes: SimpleChanges): void {    console.log(changes);}

登录后复制

我们可以通过angular官方提供的类型描述文件了解到SimpleChange的相关属性:

1.png

2.png

二、父组件监听子组件的事件获取子组件传递给父组件的值

子组件暴露一个EventEmitter(带有@Output装饰器)属性,当事件发生时,子组件利用该属性emit事件往父组件发射值。父组件绑定到这个事件属性,并在事件发生时作出回应。

子组件

child1.component.ts

@Output() voted = new EventEmitter();emitValue(): void {    this.voted.emit(true);}

登录后复制

child1.component.html

登录后复制登录后复制

父组件

parent.component.html


登录后复制登录后复制

parent.component.ts

getChildParam(value: boolean): void {    console.log(value); // true}

登录后复制

三、父组件通过本地变量(#varibleName)在模板中读取子组件的属性和调用子组件的方法

子组件

child1.component.ts

address = 'Shanghai';setAddress(address: string): void {    this.address = address;}

登录后复制

父组件

parent.component.html

{{child1Component.address}}

登录后复制

局限性:父组件-子组件的连接必须全部在父组件的模板中进行。如果父组件的类需要读取子组件的属性值或调用子组件的方法,就不能使用本地变量方法。

四、父组件调用@ViewChild

当父组件的类需要读取子组件的属性值或调用子组件的方法,就不能使用本地变量方法;如果有这种需求时,我们可以通过@ViewChild把子组件注入到父组件中;

父组件

parent.component.ts

@ViewChild(Child1Component) private child1Component!: Child1Component;

登录后复制

可以通过child1Component变量访问子组件的属性和方法;

五、利用共享服务实现任意组件之间的通信

为了实现任意组件之间的通信,我们可以结合Rxjs中的BehaviorSubject对象来创建一个共享服务;BehaviorSubject的使用可以参考这篇博客blog.tcs-y.com/2019/10/08/…

创建dataService.ts

import {BehaviorSubject} from 'rxjs';import { Injectable} from '@angular/core';@Injectable(  {providedIn: 'root'})export class DataService {  data: BehaviorSubject = new BehaviorSubject(0);}

登录后复制

在组件1的构造函数中注入服务并设置data

child1.component.ts

constructor(private dataService: DataService) {}    // 设置data的值changeData(): void {    this.dataService.data.next(10);}

登录后复制

child1.component.html

登录后复制登录后复制

在组件2的构造函数中注入服务并订阅data

child2.component.ts

constructor(private dataService: DataService) {    this.dataService.data.subscribe(value => {        console.log(value); // 10    });}

登录后复制

更多编程相关知识,请访问:编程入门!!

以上就是浅谈Angular组件之间通信的5种方法的详细内容,更多请关注【创想鸟】其它相关文章!

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

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2708802.html

(0)
上一篇 2025年3月7日 20:25:46
下一篇 2025年2月17日 22:48:18

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 手把手教你使用Angular CDK Portal创建动态内容

    之前介绍过原生 API 的动态视图插入,功能上已经可以满足大多数使用场景。不过也有一些缺憾,还没有解决在 Angular 应用外插入内容的需求,指令也不能跟动态插入的组件有输入输出的交互。 好在 Angular 官方提供了一套组件开发套件 …

    2025年3月7日
    200
  • 浅谈Angular中如何使用路由?

    angular中如何使用路由?本篇文章就来带大家了解一下angular中使用路由的方法,快速入门angular路由,希望对大家有所帮助! 路由的概念在前端的框架中得到了广泛的应用,对于路由的感念不做阐述,路由的应用无外乎就是嵌套、传参,高级…

    2025年3月7日
    200
  • 聊聊Angular中的自定义管道

    angular中管道有什么用?特点是什么?怎么自定义管道?下面本篇文章带大家了解一下angular中的管道,介绍一下自定义管道的方法,希望对大家有所帮助! 一、管道的作用 方便我们在模板中对我们的数据进行格式化处理。【相关教程推荐:《ang…

    2025年3月7日
    200
  • 深入了解Angular中的路由

    什么是路由?本篇文章带大家深入了解一下angular中的路由,希望对大家有所帮助! 路由简介 路由是实现单页面应用的一种方式,通过监听hash或者history的变化,渲染不同的组件,起到局部更新的作用,避免每次URL变化都向服务器请求数据…

    2025年3月7日
    200
  • 深入浅析Angular中的依赖注入

    什么是依赖注入?本篇文章带大家了解一下angular中的依赖注入,希望对大家有所帮助! 依赖注入概念: 维基百科对依赖注入的解释:在软件工程中,依赖注入是实现控制反转的一种软件设计模式,一个依赖是一个被其他对象(client)调用的对象(服…

    2025年3月7日
    200
  • 聊聊Angular中常用的错误处理方式

    本篇文章带大家深入了解一下angular中常用的错误处理方式,希望对大家有所帮助! 错误处理是编写代码经常遇见的并且必须处理的需求,很多时候处理异常的逻辑是为了避免程序的崩溃,本文将简单介绍Angular处理异常的方式。【相关教程推荐:《a…

    2025年3月7日
    200
  • 带你了解Angular10中的双向绑定

    下面本篇文章带大家了解一下双向绑定,看看angular中两种类型的双向绑定,希望对大家有所帮助! 前面我们了解了属性绑定、事件绑定以及输入和输出的使用,是时候了解双向绑定了。本节,我们将利用@Input()和@Output()来了解下双向绑…

    2025年3月7日 编程技术
    200
  • 浅析Angular中什么是ngModule

    什么是ngmodule?本篇文章带给大家简单了解一下angular语法,介绍一下angular中的ngmodule,希望对大家有所帮助! 作为Angular10教程,在我的理解中,angular相较于VUE,它的模块化做得更好,这样使代码结…

    2025年3月7日
    200
  • 聊聊Angular+Service如何改进日志功能

    如何改善angular的日志使用方式?下面本篇文章给大家介绍一下使用angular中的service管理控制台输出,改进日志功能的方法,希望对大家有所帮助! 改善在Angular 应用中的日志使用方式 Angular是一个非常受欢迎的开发框…

    2025年3月7日 编程技术
    200
  • 深入浅析Angular中的指令、管道和服务

    angular中什么是指令、管道、服务?下面本篇文章带大家了解一下angular中的指令、管道和服务,希望对大家有所帮助! 1. 指令 Directive 指令是 Angular 提供的操作 DOM 的途径。指令分为属性指令和结构指令。【相…

    2025年3月7日
    200

发表回复

登录后才能评论