【发布时间】:2020-07-01 13:07:05
【问题描述】:
当我切换到我的 Linux PC 时,我收到如下错误:
app/app.module.ts(21,67): error TS2304: Cannot find name 'Observable'. app/app.module.ts(25,53): error TS2304: Cannot find name 'Observable'. app/app.module.ts(29,68): error TS2304: Cannot find name 'Observable'. app/app.module.ts(33,67): error TS2304: Cannot find name 'Observable'. app/app.module.ts(37,56): error TS2304: Cannot find name 'Observable'. app/app.module.ts(52,27): error TS2304: Cannot find name 'Observable'. app/app.module.ts(52,50): error TS2304: Cannot find name 'Observable'. app/app.module.ts(54,40): error TS2304: Cannot find name '_'. app/app.module.ts(56,24): error TS2304: Cannot find name 'Observable'. app/app.module.ts(58,24): error TS2304: Cannot find name 'Observable'.
有人知道解决办法吗?
此外,我的编辑器在 HttpIntreceptor 类上显示错误,当我删除它时它工作正常......
这部分标注:Observable<Response>
你能检查一下吗:
class HttpInterceptor extends Http {
constructor(backend: ConnectionBackend, defaultOptions: RequestOptions, private _router: Router) {
super(backend, defaultOptions);
}
request(url: string | Request, options?: RequestOptionsArgs): Observable<Response> {
return this.intercept(super.request(url, options));
}
get(url: string, options?: RequestOptionsArgs): Observable<Response> {
return this.intercept(super.get(url,options));
}
post(url: string, body: string, options?: RequestOptionsArgs): Observable<Response> {
return super.post(url, body);
}
put(url: string, body: string, options?: RequestOptionsArgs): Observable<Response> {
return this.intercept(super.put(url, body, this.getRequestOptionArgs(options)));
}
delete(url: string, options?: RequestOptionsArgs): Observable<Response> {
return this.intercept(super.delete(url, options));
}
getRequestOptionArgs(options?: RequestOptionsArgs) : RequestOptionsArgs {
if (options == null) {
options = new RequestOptions();
}
if (options.headers == null) {
options.headers = new Headers();
}
options.headers.append('Content-Type', 'application/json');
return options;
}
intercept(observable: Observable<Response>): Observable<Response> {
return observable.catch((err, source) => {
if (err.status == 401 && !_.endsWith(err.url, 'api/auth/login')) {
return Observable.empty();
} else {
return Observable.throw(err);
}
});
}
}
【问题讨论】:
-
这个范围很广,也许添加您收到错误的组件。
-
看起来它是 Inerceptor 的问题,你能检查一下代码吗,主要帖子更新了...我是打字稿的新手,所以我不确定问题出在哪里...
-
是的,你是对的尝试挖掘 http 文档 angular.io/docs/ts/latest/api/http/index/Http-class.html 它看起来拦截器已经过时并且不再可用。我在 http 类定义中没有看到它
-
你导入了 Rxjs -
import 'rxjs/Rx';吗? -
是的,这是我现在才发现的问题...
import {Observable} from 'rxjs/Rx'; import 'rxjs/add/operator/map';
标签: angular typescript