ngrx EffectsModule 使 Http 服务未定义
ngrx EffectsModule makes Http service undefined
使用 @ngrx/effects
v4.0.5 和 Angular v4.4.4.
当我在 app.module.ts
中导入 EffectsModule
时,Http 服务变得未定义。
一些代码:
// app.module.ts
import { BrowserModule, Title } from '@angular/platform-browser';
...
import { HttpModule, Http } from '@angular/http';
...
import { EffectsModule } from '@ngrx/effects';
import { AuthenticationModule } from './authentication/authentication.module';
import { MyEffects } from './myEffects.ts'
...
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
HttpModule,
...
AuthenticationModule,
StoreModule.forRoot(reducers),
EffectsModule.forRoot([MyEffects])
]
...
})
export class AppModule { }
请注意 MyEffects
与身份验证功能没有任何关系。
当我使用第一个可以在我的应用程序中使用的东西时,登录按钮,我调用 AuthenticationService.signIn,它又调用它的 http 实例 this.http.post(...
并且 this.http
是未定义的(收到一条错误消息,通过调试器查看它,发现它未定义 - this
不是未定义的并且有一个 http
属性 未定义)
如果我注释掉 EffectsModule.forRoot([MyEffects])
,http 服务 "reappears" 和登录工作。
请注意 MyEffects
与身份验证功能没有任何关系。
将 @angular/
软件包从 4.4.4
升级到 4.4.5
解决了问题 O_O'
使用 @ngrx/effects
v4.0.5 和 Angular v4.4.4.
当我在 app.module.ts
中导入 EffectsModule
时,Http 服务变得未定义。
一些代码:
// app.module.ts
import { BrowserModule, Title } from '@angular/platform-browser';
...
import { HttpModule, Http } from '@angular/http';
...
import { EffectsModule } from '@ngrx/effects';
import { AuthenticationModule } from './authentication/authentication.module';
import { MyEffects } from './myEffects.ts'
...
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
HttpModule,
...
AuthenticationModule,
StoreModule.forRoot(reducers),
EffectsModule.forRoot([MyEffects])
]
...
})
export class AppModule { }
请注意 MyEffects
与身份验证功能没有任何关系。
当我使用第一个可以在我的应用程序中使用的东西时,登录按钮,我调用 AuthenticationService.signIn,它又调用它的 http 实例 this.http.post(...
并且 this.http
是未定义的(收到一条错误消息,通过调试器查看它,发现它未定义 - this
不是未定义的并且有一个 http
属性 未定义)
如果我注释掉 EffectsModule.forRoot([MyEffects])
,http 服务 "reappears" 和登录工作。
请注意 MyEffects
与身份验证功能没有任何关系。
将 @angular/
软件包从 4.4.4
升级到 4.4.5
解决了问题 O_O'