angular5 - 通过 Angular 中的服务发出事件

标签 angular5

通过服务发出事件的正确方法是什么。我读过在服务中声明 EventEmmiter 是不合适的。

我想实现以下目标。

我在根组件内有2个组件,当我点击第一个组件时,我想知道第一个组件在第二个组件中被点击了。

最佳答案

您可以在四种可能的情况下共享您的数据,但这取决于您的要求

parent 对 child :通过输入共享数据

child 到 parent :通过 ViewChild 共享数据

子到父:通过 Output() 和 EventEmitter 共享数据

不相关的组件:与服务共享数据

在缺少直接连接的组件之间传递数据时,例如兄弟孙子等,您应该使用共享服务。当您有应该同步的数据时,我发现 RxJS BehaviorSubject 在这种情况下非常有用。

您也可以使用常规的 RxJS 主题通过服务共享数据,但这就是我更喜欢 BehaviorSubject 的原因。

它总是会在 subscription 上返回当前值 - 无需调用 onnext 它有一个 getValue() 函数来提取最后一个值作为原始数据。 它确保组件始终接收最新数据。 在服务中,我们创建一个私有(private)的 BehaviorSubject 来保存消息的当前值。我们定义了一个 currentMessage 变量,将这个数据流作为一个 observable 来处理,供组件使用。最后,我们创建函数,调用 BehaviorSubject 上的 next 来更改其值。

父组件、子组件和兄弟组件都接受相同的处理。我们在构造函数中注入(inject) DataService,然后订阅 currentMessage observable 并将其值设置为等于 message 变量。

现在,如果我们在其中任何一个组件中创建一个函数来更改消息的值。当执行此函数时,新数据会自动广播到所有其他组件。 这是一个代码片段。

data.service.ts

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

@Injectable()
export class DataService {

  private messageSource = new BehaviorSubject('default message');
  currentMessage = this.messageSource.asObservable();

  constructor() { }

  changeMessage(message: string) {
    this.messageSource.next(message)
  }

}

parent.component.ts

import { Component, OnInit } from '@angular/core';
import { DataService } from "../data.service";

@Component({
  selector: 'app-parent',
  template: `
    {{message}}
  `,
  styleUrls: ['./sibling.component.css']
})
export class ParentComponent implements OnInit {

  message:string;

  constructor(private data: DataService) { }

  ngOnInit() {
    this.data.currentMessage.subscribe(message => this.message = message)
  }

}

second.component.ts

import { Component, OnInit } from '@angular/core';
import { DataService } from "../data.service";

@Component({
  selector: 'app-sibling',
  template: `
    {{message}}
    <button (click)="newMessage()">New Message</button>
  `,
  styleUrls: ['./sibling.component.css']
})
export class SiblingComponent implements OnInit {

  message:string;

  constructor(private data: DataService) { }

  ngOnInit() {
    this.data.currentMessage.subscribe(message => this.message = message)
  }

  newMessage() {
    this.data.changeMessage("Hello from Sibling")
  }

}

关于angular5 - 通过 Angular 中的服务发出事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56414236/

相关文章:

angular - 无法读取未定义的属性 'schedule'

angular - 将日期范围添加到 NgbInputDatepicker 输入字段

angular5 - *ngIf 中的 AsyncPipe

javascript - Angular 5 : Multiple requests at once with forkJoin

angular - ngx-perfect-scrollbar 中的水平滚动

angular-reactive-forms - Angular 5 - 响应式(Reactive)表单不会在提交时验证表单

javascript - Angular:显示文本区域内的文本区域字符数

html - 如何为不同的 Angular 5 页面应用不同的(整页)背景?

javascript - 为什么我们使用 javascript :void(0) in Angular code

angular - 在Angular 5+中创建动态组件时的ReflectiveInjector与Injector