Angular中非父子组件间是如何通讯的

发布时间:2021-11-15 10:53:15 作者:iii
来源:亿速云 阅读:161

本篇内容介绍了“Angular中非父子组件间是如何通讯的”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

Angular中非父子组件间是如何通讯的

其实提到父子组件之间传值,对我们来说,再熟悉不过了,在业务实现过程中很常见。

但是我在实现的过程中涉及到跨级了(也就是非父子组件之间传值),是的,我可以一层一层地往上传递,在父组件中拿到子组件的传值,那有没有更好的方式呢?

需求背景:

有一个子组件,可以理解为第三级组件,该组件中有个下拉框,当点击某个li标签的时候,需要将相应选中的值传给第一级组件,同时,一级组件带着接收到的值请求列表接口,进而刷新数据。

最初思路:

当时想着通过localstorage将用户选中的值保存下来,在使用的组件中,再通过localstorage将值取出来,拿着该值请求接口;但是,无法做到实时,用户选中后,没有触发我在父组件中获取数据,也就是子组件中的值改变了,如何通知到父组件。

技术点:

Angular父组件和子组件通过服务来通讯

父组件和它的子组件共享同一个服务,利用该服务在组件家族内部实现双向通讯。

该服务实例的作用域被限制在父组件和其子组件内。这个组件子树之外的组件将无法访问该服务或者与它们通讯。

原理

父组件和它的子组件共享同一个服务,利用该服务在组件家族内部实现双向通讯。

该服务实例的作用域被限制在父组件和其子组件内。这个组件子树之外的组件将无法访问该服务或者与它们通讯。 服务是子组件与父组件之间的桥梁,因为服务可以很方便的注入到其它的组件当中,又因为Subject对象可以将数据多播(传递)给订阅了这个对象的组件,因此结合Angular中的service和Rxjs中的Subject可以很方便的实现组件间的数据通讯。

实现:

在该子组件中创建一个service文件,代码如下:

import { Injectable } from '@angular/core';
import { Subject } from 'rxjs';

@Injectable({
  providedIn: 'root'
})
export class HeaderActionService {
  public pageTenantMode = new Subject<string>();
  // 获得一个Observable;
  missionConfirmed$ = this.pageTenantMode.asObservable();
  constructor() {}

  setParams(params) {
    this.pageTenantMode.next(params);
  }
}

子组件数据层调用上述方法,将值传进去。

this.tenantModeService.setParams()

父组件调用的地方注入上述服务,代码如下:

    headerModeService.missionConfirmed$.subscribe(
        () => {
          this.mode = headerModeService.pageTenantMode;
          this.initTableData();
        }
      );

“Angular中非父子组件间是如何通讯的”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

推荐阅读:
  1. Vue入门八、非父子组件间通讯
  2. Vue入门七、父子组件间通讯

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

angular

上一篇:怎么配置nginx的反向代理

下一篇:jquery如何控制a标签跳转

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》