RXJS的Subscribe方法中的主题

时间:2018-12-31 10:26:49

标签: angular rxjs observable subject behaviorsubject

我已基于Angular 2+的RXJS克隆了一个Github存储库。 帮我了解this.createTodo $ .subscribe(this.create $)的含义 在下面的代码中。

我能够理解,这里我们尝试订阅可观察的createTodo $。在subscribe方法中,我总是设置数据,但是做什么 this.create $的意思是。这里的create $是一个Subject。

请找到进行此订阅的服务代码。

import { Injectable } from '@angular/core';
import { BehaviorSubject, Observable ,Subject} from 'rxjs';
import {  itemmodel } from './models/listmodel';
import {scan,map} from 'rxjs/operators';

type TodosOperation = (todos: itemmodel[]) => itemmodel[];
const initialTodos=[];

@Injectable({
  providedIn: 'root'
})

export class SharedserviceService {
  public data;
  create$: Subject<itemmodel> = new Subject<itemmodel>();
  createTodo$: Subject<itemmodel> = new Subject<itemmodel>();
  todos$:Observable<itemmodel[]>;
  public item = new BehaviorSubject([]);
  update$: BehaviorSubject<TodosOperation> = new BehaviorSubject<TodosOperation>((todos: itemmodel[]) => todos);

  constructor(){ 
    this.todos$ = this.update$.pipe(scan((todos: itemmodel[], operation: TodosOperation) => operation(todos), initialTodos));

    this.create$.pipe(map((todo) => {
      return (todos) => todos.concat(todo);
    })).subscribe(this.update$);

    this.createTodo$.subscribe(this.create$);
  }

  public additem(item){
    this.createTodo$.next(item);
  }

}

1 个答案:

答案 0 :(得分:0)

这是一个命名约定。使用te美元符号($)表示变量是流(观察者)。

要观看视频流,请订阅它