首页前端开发JavaScript浅析Angular中非父子组件间怎么通讯

浅析Angular中非父子组件间怎么通讯

时间2024-01-30 18:18:02发布访客分类JavaScript浏览211
导读:收集整理的这篇文章主要介绍了浅析Angular中非父子组件间怎么通讯,觉得挺不错的,现在分享给大家,也给大家做个参考。Angular中非父子组件间怎么通讯?本篇文章给大家介绍一下Angular非父子组件之间通过服务通讯的方法,希望对大家有所...
收集整理的这篇文章主要介绍了浅析Angular中非父子组件间怎么通讯,觉得挺不错的,现在分享给大家,也给大家做个参考。Angular中非父子组件间怎么通讯?本篇文章给大家介绍一下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 Subjectstring>
    ();
      // 获得一个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中非父子组件间怎么通讯的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

Angular组件通讯

若转载请注明出处: 浅析Angular中非父子组件间怎么通讯
本文地址: https://pptw.com/jishu/592870.html
浅析怎么利用npkill快速找到和删除node C#中异步编程4async与await异步程序开发的实例分析

游客 回复需填写必要信息