return 条件 rxjs Observable 的更好方法
Better way to return conditional rxjs Observable
在下面的代码中,函数onReady1()
和onReady2()
是等价的吗?有什么区别?有没有更好的方法来编写这个函数?
onReadyx()
函数应该 return 用户如果它立即可用,或者它会等到它可用。在任何给定时间都会多次调用此函数。
export class UserService {
private _user: IUser;
private userObservable: Observable<IUser>;
constructor(private http: Http) {
this.userObservable = this.getCurrentUser();
}
public onReady1() {
return Observable.create((observer: Observer<IUser>) => {
if (this._user) {
observer.next(this._user);
observer.complete();
return;
}
this.userObservable.subscribe(user => {
this._user = user;
observer.next(user);
observer.complete();
});
});
}
public onReady2() {
return Observable.defer(() => {
if (this._user) {
return Observable.of(this._user);
}
return this.userObservable.do(user => this._user = user);
});
}
private getCurrentUser() {
return this.http.get('/currentuser')
.map(response => response.json() as IUser);
}
}
使用 publishLast
export class Service {
private sharedStream$: Observable< IUser>;
constructor(public http: AuthHttp) {
this.sharedStream$ = this. getCurrentUser()
.publishLast()
.refCount();
}
getUserObservable(): Observable< IUser> {
return this.sharedStream$;
}
}
在下面的代码中,函数onReady1()
和onReady2()
是等价的吗?有什么区别?有没有更好的方法来编写这个函数?
onReadyx()
函数应该 return 用户如果它立即可用,或者它会等到它可用。在任何给定时间都会多次调用此函数。
export class UserService {
private _user: IUser;
private userObservable: Observable<IUser>;
constructor(private http: Http) {
this.userObservable = this.getCurrentUser();
}
public onReady1() {
return Observable.create((observer: Observer<IUser>) => {
if (this._user) {
observer.next(this._user);
observer.complete();
return;
}
this.userObservable.subscribe(user => {
this._user = user;
observer.next(user);
observer.complete();
});
});
}
public onReady2() {
return Observable.defer(() => {
if (this._user) {
return Observable.of(this._user);
}
return this.userObservable.do(user => this._user = user);
});
}
private getCurrentUser() {
return this.http.get('/currentuser')
.map(response => response.json() as IUser);
}
}
使用 publishLast
export class Service {
private sharedStream$: Observable< IUser>;
constructor(public http: AuthHttp) {
this.sharedStream$ = this. getCurrentUser()
.publishLast()
.refCount();
}
getUserObservable(): Observable< IUser> {
return this.sharedStream$;
}
}