【发布时间】:2017-06-27 19:16:03
【问题描述】:
在另一个服务中注入服务时遇到问题。 我有一个 ContactService 使用 handleError 方法从服务器获取数据。 我有一个 AlertService 从 handleError 方法抛出错误。 我已经在我的核心模块中声明了contactService 和AlertService。 但是当我调用 alertService.submitNewMessage 时,它显示 this.alertService 是未定义的。 请帮忙
@Injectable()
export class AlertService {
private $currentMessages: BehaviorSubject<string> = new BehaviorSubject('');
public currentMessages: Observable<string> = this.$currentMessages.asObservable();
constructor() { }
submitNewMessage(msg: string): void {
this.$currentMessages.next(msg);
}
}
并联系服务
@Injectable()
export class ContactService {
private contactsUrl = 'http://localhost/customers';
constructor(
private http: Http,
private router: Router,
private alertService: AlertService
) { }
getContactsFromService(): Observable<SubmitCustomerHttp[]> {
return this.http.get(this.contactsUrl)
.map(this.extractData)
.catch(this.handleError);
}
private extractData(res: Response) {
return HttpHelper.extractData(res);
}
handleError(error: Response | any) {
let errMsg: string;
console.log('Receive error: ', error);
if (error instanceof Response) {
const body = error.json() || '';
const err = body.error || JSON.stringify(body);
errMsg = `${error.status} - ${error.statusText || ''} ${err}`;
if (error.status === 500 || 400 || 404) {
window.alert(errMsg);
this.alertService.submitNewMessage(errMsg);
return errMsg;
}
} else {
errMsg = error.message ? error.message : error.toString();
console.log('Error Message: ', errMsg);
return null;
}
}
}
我的核心模块
@NgModule({
imports: [
CommonModule,
HttpModule,
JsonpModule
],
declarations: [],
providers: [
AlertService,
ContactService,
]
})
export class CoreModule {
static forRoot(): ModuleWithProviders {
return {
ngModule: CoreModule,
providers: [
AlertService,
ContactService,
]
};
}
}
【问题讨论】:
-
alertService.submitNewMessage 的代码在哪里?
-
@Sajeetharan 对不起,我的错误,我会改正的
-
你的contactservice没有用@Injectable修饰
标签: angular typescript angular2-services