我在 app.module.ts
中为CookieXSRFStrategy
提供XSRFStrategy
providers: [
{ provide: APP_BASE_HREF, useValue: '/order/' },
{ provide: XSRFStrategy, useValue: new CookieXSRFStrategy('csrftoken', 'X-CSRFToken') },
{ provide: RequestOptions, useClass: DefaultRequestOptions }
],
在第二次构建时使用watch / serve工作正常,但在使用--prod标志构建时,收到此错误:
ERROR in Error遇到静态解析符号值。 不支持函数调用。考虑更换功能或 lambda引用导出函数(位置50:34) 原始.ts文件),解析符号AppModule E:/repo/src/app/app.module.ts
ng --version
@angular/cli: 1.0.0
node: 6.9.1
os: win32 x64
@angular/common: 4.0.0
@angular/compiler: 4.0.0
@angular/core: 4.0.0
@angular/forms: 4.0.0
@angular/http: 4.0.0
@angular/platform-browser: 4.0.0
@angular/platform-browser-dynamic: 4.0.0
@angular/router: 4.0.0
@angular/animations: 4.0.0
@angular/cli: 1.0.0
@angular/compiler-cli: 4.0.0
答案 0 :(得分:9)
回答我自己的问题,发现我必须使用对导出函数的引用,所以使用like:
providers: [
{ provide: APP_BASE_HREF, useValue: '/order/' },
{ provide: XSRFStrategy, useValue: cookieStrategy },
{ provide: RequestOptions, useClass: DefaultRequestOptions }
],
export function cookieStrategy() {
return new CookieXSRFStrategy('csrftoken', 'X-CSRFToken');
}
编译好,但是给出了运行时错误:as
ERROR TypeError:this._xsrfStrategy.configureRequest不是函数
更改 useValue 以提供 useFactory 修复问题
providers: [
{ provide: APP_BASE_HREF, useValue: '/order/' },
{ provide: XSRFStrategy, useFactory: cookieStrategy },
{ provide: RequestOptions, useClass: DefaultRequestOptions }
],