【发布时间】:2018-02-21 11:49:33
【问题描述】:
我遇到了 flatMap 运算符的随机行为,我找不到原因。有时会触发,有时不会...
情况如下: 用户可以在我的应用程序中更改语言,因此我有一个关于语言(由选择列表触发)的 BehaviorSubject,作为其提供者的可观察对象返回。当发生更改时,我调用(通过 flatMap)一个 http 请求以获取所选语言的数据。
看起来像这样:
this.languageProvider.getLang$().flatMap(langCode => {
return this.http.get(`https://SERVER_URL.net/datas?lang=${langCode}`)
.map(data => data.json())
})
.subscribe(
data => {
// do smth
},
err => {
// do smth
}
);
问题是,当我更改语言时,通常不会触发 http 调用。
如果我添加一个简单的订阅,它总是可以工作...
this.languageProvider.getLang$().subscribe(langCode => {
console.log(langCode);
});
知道我为什么会遇到这个问题吗?
这里是语言提供者:
import { Injectable } from '@angular/core';
import { BehaviorSubject } from 'rxjs/BehaviorSubject';
import { Observable } from 'rxjs/Observable';
@Injectable()
export class LanguageProvider {
private lang$: BehaviorSubject<string>;
constructor() {
this.lang$ = new BehaviorSubject('en');
}
setLang(langCode: string) {
this.lang$.next(langCode);
}
getLang$(): Observable<string> {
return this.lang$.asObservable();
}
}
非常感谢
【问题讨论】:
标签: javascript angular rxjs observable flatmap