我正在使用APP_INITIALIZER,就像在this的回答中推荐的那样,我的服务返回了一个承诺,但它并不总是等待它解决,我可以看到我的组件console.logging undefined,然后服务记录下载的对象。Angular2 APP_INITIALIZER不一致
我需要的应用程序在此数据加载之前不做任何事情。
app.module.ts
import { NgModule, APP_INITIALIZER } from '@angular/core';
import { Http, HttpModule, JsonpModule } from '@angular/http';
import { UserService } from '../services/user.service';
<...>
@NgModule({
imports: [
BrowserModule,
HttpModule,
FormsModule,
JsonpModule,
routing
],
declarations: [
AppComponent,
<...>
],
providers: [
<...>
UserService,
{provide: APP_INITIALIZER,
useFactory: (userServ: UserService) =>() => userServ.getUser(),
deps: [UserService, Http],
multi: true
}
],
bootstrap: [AppComponent]
user.service.ts
@Injectable()
export class UserService {
public user: User;
constructor(private http: Http) { }
getUser(): Promise<User> {
console.log('get user called');
var observable= this.http.get('/auth/getuser', { headers: getHeaders() })
.map(extractData);
observable.subscribe(user => {this.user = user;
console.log(this.user)});
return observable.toPromise();
}
}
它看起来OK。请说明您正在使用的软件包版本。你是否能够将问题复制为小提琴? – estus
我不确定你为什么获取未定义值的日志,但是如果你在observable上同时使用'toPromise()'和'subscribe()',你将会调用'/ auth/getuser'两次。你应该链接rxjs运算符'share()'('rxjs/add/operator/share') –