为什么`combineLatest`返回OperatorFunction <{},number>

Abr*_*kad 6 rxjs angular

我正在使用rxjs 6我的代码中有两个observable

import { combineLatest } from 'rxjs/operators';

loading$: Observable<boolean>;
loaded$: Observable<boolean>;
Run Code Online (Sandbox Code Playgroud)

可观测量不是来自http请求,而是来自store

我需要在合并/转换序列基于这个逻辑一个单一可观察值:
如果序列true,true或者false,false-需要返回新观察到的true,否则需要返回false

我试图用它combineLatest来实现:

combineLatest(
    this.loaded$, this.loading$,
    (val1, val2) => Number(val1) + Number(val2) === 1
)
Run Code Online (Sandbox Code Playgroud)

但问题是我的combineLatest回报'OperatorFunction<>而不是Observable<>我不能订阅.你有任何想法如何解决这个问题?或者,如果有另一种方法可以采取?

更新:
似乎这是我import { combineLatest } from 'rxjs';
目前测试的问题的答案

mar*_*tin 9

使用RxJS 5.5时,最有可能的原因是因为您正在使用它combineLatest,rxjs/operators而您希望将其用作"创建"运算符,这意味着您需要使用它rxjs/observable/combineLatest.

我的意思是你需要使用这个:

import { combineLatest } from 'rxjs/observable/combineLatest';
Run Code Online (Sandbox Code Playgroud)

......而不是这个:

import { combineLatest } from 'rxjs/operators';
Run Code Online (Sandbox Code Playgroud)

编辑:由于您提到您正在使用RxJS 6,您可以直接导入rxjs(假设您为捆绑器设置了正确的路径映射).

import { combineLatest } from 'rxjs';
Run Code Online (Sandbox Code Playgroud)

如果你无法控制你的构建系统,那么这也应该有效:

import { combineLatest } from 'rxjs/operators';
Run Code Online (Sandbox Code Playgroud)