我的console.log永不被调用(我的2个请求已被调用并且确定)。
const obs1 = this.awsService.getUsers();
const obs2 = this.apiService.get('admin/user');
return forkJoin(obs1, obs2).subscribe((res) => {
console.log('res2', res);
});
我尝试单元呼叫(console.log A和B可以):
const obs1 = this.awsService.getUsers();
obs1.subscribe((res) => {
console.log('A' + res);
});
const obs2 = this.apiService.get('admin/user');
obs2.subscribe((res) => {
console.log('B' + res);
});
编辑
我的代码返回一个可观察到的User [],但不是一个forkJoin:
getUsers(): Observable<User[]> {
return Observable.create(obs => {
const u = new User;
u.username = user.Username;
_users.push(u);
return obs.next(_users);
});
}
此代码没问题:
const u1: User = new User;
u1.username = 'foo';
const u2: User = new User;
u2.username = 'foo';
const o2: Observable<User[]> = of([u1, u2]);
const fj = forkJoin(o2);
fj.subscribe(res => {
console.log('r');
});
// r is ok in console
of
和Observable.create( ... return obs.next(_users);)
之间有什么区别?
答案 0 :(得分:1)
create和of之间的区别是,根据定义,发射一个项目后完成。除非您指定创建,否则创建不会完成。
如果您这样做:
getUsers(): Observable<User[]> {
return Observable.create(obs => {
const u = new User;
u.username = user.Username;
_users.push(u);
obs.next(_users);
obs.complete();
return () => {}; // return value should be clean up function on completion if needed
});
}
然后它将起作用,因为您在发射后立即完成。 forkJoin期望所有流都将完成,并且直到所有流都具有时才会发出,并且仅以流中的最新值发出。
如果您实际上想要所有排放物,请考虑使用CombineLatest