iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Angular组件间进行通信的方法有哪些
  • 253
分享到

Angular组件间进行通信的方法有哪些

2023-07-04 21:07:09 253人浏览 泡泡鱼
摘要

这篇“angular组件间进行通信的方法有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Angular组件间进行通信的方

这篇“angular组件间进行通信的方法有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Angular组件间进行通信的方法有哪些”文章吧。

1. 父组件通过属性传递值给子组件

相当于你自定义了一个属性,通过组件的引入,将值传递给子组件。Show you the CODE

<!-- parent.component.html --><app-child [parentProp]="'My kid.'"></app-child>

在父组件中调用子组件,这里命名一个 parentProp 的属性。

// child.component.tsimport { Component, OnInit, Input } from '@angular/core';@Component({  selector: 'app-child',  templateUrl: './child.component.html',  styleUrls: ['./child.component.sCSS']})export class ChildComponent implements OnInit {  // 输入装饰器  @Input()  parentProp!: string;  constructor() { }  nGonInit(): void {  }}

子组件接受父组件传入的变量 parentProp,回填到页面。

<!-- child.component.html --><h2>Hello! {{ parentProp }}</h2>

2. 子组件通过 Emitter 事件传递信息给父组件

通过 new EventEmitter() 将子组件的数据传递给父组件。

// child.component.tsimport { Component, OnInit, Output, EventEmitter } from '@angular/core';@Component({  selector: 'app-child',  templateUrl: './child.component.html',  styleUrls: ['./child.component.scss']})export class ChildComponent implements OnInit {  // 输出装饰器  @Output()  private childSayHi = new EventEmitter()  constructor() { }  ngOnInit(): void {    this.childSayHi.emit('My parents');  }}

通过 emit 通知父组件,父组件对事件进行监听。

// parent.component.tsimport { Component, OnInit } from '@angular/core';@Component({  selector: 'app-communicate',  templateUrl: './communicate.component.html',  styleUrls: ['./communicate.component.scss']})export class CommunicateComponent implements OnInit {  public msg:string = ''  constructor() { }  ngOnInit(): void {  }  fromChild(data: string) {    // 这里使用异步    setTimeout(() => {      this.msg = data    }, 50)  }}

在父组件中,我们对 child 组件来的数据进行监听后,这里采用了 setTimeout 的异步操作。是因为我们在子组件中初始化后就进行了 emit,这里的异步操作是防止 Race Condition 竞争出错。

我们还得在组件中添加 fromChild 这个方法,如下:

<!-- parent.component.html --><h2>Hello! {{ msg }}</h2><app-child (childSayHi)="fromChild($event)"></app-child>

3. 通过引用,父组件获取子组件的属性和方法

我们通过操纵引用的方式,获取子组件对象,然后对其属性和方法进行访问。

我们先设置子组件的演示内容:

// child.component.tsimport { Component, OnInit } from '@angular/core';@Component({  selector: 'app-child',  templateUrl: './child.component.html',  styleUrls: ['./child.component.scss']})export class ChildComponent implements OnInit {  // 子组件的属性  public childMsg:string = 'Prop: message from child'  constructor() { }  ngOnInit(): void {      }  // 子组件方法  public childSayHi(): void {    console.log('Method: I am your child.')  }}

我们在父组件上设置子组件的引用标识 #childComponent

<!-- parent.component.html --><app-child #childComponent></app-child>

之后在 javascript 文件上调用:

import { Component, OnInit, ViewChild } from '@angular/core';import { ChildComponent } from './components/child/child.component';@Component({  selector: 'app-communicate',  templateUrl: './communicate.component.html',  styleUrls: ['./communicate.component.scss']})export class CommunicateComponent implements OnInit {  @ViewChild('childComponent')  childComponent!: ChildComponent;  constructor() { }  ngOnInit(): void {    this.getChildPropAndMethod()  }  getChildPropAndMethod(): void {    setTimeout(() => {      console.log(this.childComponent.childMsg); // Prop: message from child      this.childComponent.childSayHi(); // Method: I am your child.    }, 50)  }}

这种方法有个限制?,就是子属性的修饰符需要是 public,当是 protected 或者 private 的时候,会报错。你可以将子组件的修饰符更改下尝试。报错的原因如下:

类型使用范围
public允许在累的内外被调用,作用范围最广
protected允许在类内以及继承的子类中使用,作用范围适中
private允许在类内部中使用,作用范围最窄

4. 通过 service 去变动

我们结合 rxjs 来演示。

rxjs 是使用 Observables 的响应式编程的库,它使编写异步或基于回调的代码更容易。

后期会有一篇文章记录 rxjs,敬请期待

我们先来创建一个名为 parent-and-child 的服务。

// parent-and-child.service.tsimport { Injectable } from '@angular/core';import { BehaviorSubject, Observable } from 'rxjs'; // BehaviorSubject 有实时的作用,获取最新值@Injectable({  providedIn: 'root'})export class ParentAndChildService {  private subject$: BehaviorSubject<any> = new BehaviorSubject(null)  constructor() { }    // 将其变成可观察  getMessage(): Observable<any> {    return this.subject$.asObservable()  }  setMessage(msg: string) {    this.subject$.next(msg);  }}

接着,我们在父子组件中引用,它们的信息是共享的。

// parent.component.tsimport { Component, OnDestroy, OnInit } from '@angular/core';// 引入服务import { ParentAndChildService } from 'src/app/services/parent-and-child.service';import { Subject } from 'rxjs'import { takeUntil } from 'rxjs/operators'@Component({  selector: 'app-communicate',  templateUrl: './communicate.component.html',  styleUrls: ['./communicate.component.scss']})export class CommunicateComponent implements OnInit, OnDestroy {  unsubscribe$: Subject<boolean> = new Subject();  constructor(    private readonly parentAndChildService: ParentAndChildService  ) { }  ngOnInit(): void {    this.parentAndChildService.getMessage()      .pipe(        takeUntil(this.unsubscribe$)      )      .subscribe({        next: (msg: any) => {          console.log('Parent: ' + msg);           // 刚进来打印 Parent: null          // 一秒后打印 Parent: Jimmy        }      });    setTimeout(() => {      this.parentAndChildService.setMessage('Jimmy');    }, 1000)  }  ngOnDestroy() {    // 取消订阅    this.unsubscribe$.next(true);    this.unsubscribe$.complete();  }}
import { Component, OnInit } from '@angular/core';import { ParentAndChildService } from 'src/app/services/parent-and-child.service';@Component({  selector: 'app-child',  templateUrl: './child.component.html',  styleUrls: ['./child.component.scss']})export class ChildComponent implements OnInit {  constructor(    private parentAndChildService: ParentAndChildService  ) { }      // 为了更好理解,这里我移除了父组件的 Subject  ngOnInit(): void {    this.parentAndChildService.getMessage()      .subscribe({        next: (msg: any) => {          console.log('Child: '+msg);          // 刚进来打印 Child: null          // 一秒后打印 Child: Jimmy        }      })  }}

在父组件中,我们一秒钟之后更改值。所以在父子组件中,一进来就会打印 msg 的初始值 null,然后过了一秒钟之后,就会打印更改的值 Jimmy。同理,如果你在子组件中对服务的信息,在子组件打印相关的值的同时,在父组件也会打印。

以上就是关于“Angular组件间进行通信的方法有哪些”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。

--结束END--

本文标题: Angular组件间进行通信的方法有哪些

本文链接: https://www.lsjlt.com/news/347469.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Angular组件间进行通信的方法有哪些
    这篇“Angular组件间进行通信的方法有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Angular组件间进行通信的方...
    99+
    2023-07-04
  • Angular组件间进行交互的方法有哪些
    本篇内容介绍了“Angular组件间进行交互的方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、...
    99+
    2024-04-02
  • 带你了解Angular组件间进行通信的几种方法
    本文纯文字,比较枯燥。因为控制台打印的东西比较鸡肋,所以就不配图了,嗯~希望读者跟着说明代码走一遍更容易吸收~1. 父组件通过属性传递值给子组件相当于你自定义了一个属性,通过组件的引入,将值传递给子组件。Show you the CODE。...
    99+
    2023-05-14
    Angular 组件通信
  • Angular父子组件间如何进行通信
    小编给大家分享一下Angular父子组件间如何进行通信,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!组件通信组件是一个完整独立的...
    99+
    2024-04-02
  • Vue组件间通信的方法有哪些
    这篇“Vue组件间通信的方法有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue组件间通信的方法有哪些”文章吧。方法一...
    99+
    2023-07-05
  • React组件间通信的方法有哪些
    这篇文章给大家分享的是有关React组件间通信的方法有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、父子组件通信原理:父组件通过props(与vue中的props区分开)向子组件通信,子组件通过回调事件与...
    99+
    2023-06-25
  • Angular组件如何进行通信
    小编给大家分享一下Angular组件如何进行通信,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!准备一下我们的环境:1、创建一个h...
    99+
    2024-04-02
  • Angular中父子组件间如何进行通信
    今天就跟大家聊聊有关Angular中父子组件间如何进行通信,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。通过Input和Ouput传值父组件:htm...
    99+
    2024-04-02
  • React组件间通信方式有哪些
    这篇文章主要介绍React组件间通信方式有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!组件间通信方式总结父组件 => 子组件:PropsInstance Methods子组件 => 父组件:Call...
    99+
    2023-06-06
  • qt进程间通信的方法有哪些
    Qt进程间通信的方法有以下几种: 信号与槽:通过Qt的信号与槽机制,可以在不同的进程之间进行通信。一个进程可以发射信号,另一个进...
    99+
    2023-10-21
    qt
  • vue组件之间通信方式有哪些
    这篇文章将为大家详细讲解有关vue组件之间通信方式有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体如下:对于vue来说,组件之间的消息传递是非常重要的,下面是我对...
    99+
    2024-04-02
  • Vue实现组件间通信的方式有哪些
    本篇内容主要讲解“Vue实现组件间通信的方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue实现组件间通信的方式有哪些”吧!1、Props 父 >>> 子&...
    99+
    2023-06-25
  • vue中组件间相互通信传值的方法有哪些
    这篇文章主要讲解了“vue中组件间相互通信传值的方法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue中组件间相互通信传值的方法有哪些”吧!vue中组件之间相互通讯传值的方式我们在使...
    99+
    2023-06-29
  • angular组件传值的方法有哪些
    Angular组件之间传值的方法有以下几种: 输入属性(@Input):在子组件上通过@Input装饰器定义一个输入属性,然后在...
    99+
    2023-10-24
    angular
  • vue组件间如何进行通信
    本篇内容介绍了“vue组件间如何进行通信”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!vue是数据驱动视图更新的框架, 我们平时开发,都会把...
    99+
    2023-06-21
  • Angular组件之间是怎么通信的
    这篇文章主要介绍“Angular组件之间是怎么通信的”,在日常操作中,相信很多人在Angular组件之间是怎么通信的问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Angula...
    99+
    2024-04-02
  • Android进程间通信的方式有哪些
    Android进程间通信的方式有以下几种:1. Intent:通过Intent对象进行进程间的通信。可以使用隐式Intent在不同的...
    99+
    2023-10-08
    Android
  • Angular中组件间通讯的实现方法
    这篇文章主要介绍Angular中组件间通讯的实现方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Angular 组件间的通讯组件间三种典型关系:父好组件之间的交互(@Input/@Output/模板变量/@View...
    99+
    2023-06-14
  • vue中实现组件间通信的方式有哪些
    这篇文章给大家介绍vue中实现组件间通信的方式有哪些,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。方法一、 props / $emit父组件A通过props的方式向子组件B传递,B t...
    99+
    2024-04-02
  • Linux进程间的通信方式有哪些
    本篇内容主要讲解“Linux进程间的通信方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux进程间的通信方式有哪些”吧!进程的概念进程是操作系统的概念,每当我们执行一个程序时,对于...
    99+
    2023-06-16
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作