错误TS2304:找不到名称'Observable'Angularjs 2

Vla*_*mir 15 typescript angular

当我切换到我的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'.
Run Code Online (Sandbox Code Playgroud)

有人知道解决方案吗?

我的编辑器也显示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);
            }
        });

    }
}
Run Code Online (Sandbox Code Playgroud)

Tah*_*ued 39

我通过导入Observable修复了同样的问题

import {Observable} from 'rxjs/Rx';
Run Code Online (Sandbox Code Playgroud)

  • 它说 node_modules/rxjs/Rx"' 没有导出成员 'Observable'。 (2认同)

Kow*_*lya 17

你可以通过两种方式完成它

1.导入Observable,然后导入其他函数,如map,do,catch,throw,无论你使用哪个

import {Observable} from 'rxjs/Observable';
import 'rxjs/add/operator/map';
import 'rxjs/add/operator/catch';
.....
.....
import 'rxjs/add/observable/throw';
Run Code Online (Sandbox Code Playgroud)

2.导入整个Rxjs

import {Observable} from 'rxjs/Rx';
Run Code Online (Sandbox Code Playgroud)

要么

import {Observable} from 'rxjs';
Run Code Online (Sandbox Code Playgroud)

建议使用第一种方法,由于导入整个rxjs是没有必要的,并且将包括所有的子模块进入捆束影响的大小和负载时间

  • 在 Angular 8 中,您可以使用“import {Observable} from 'rxjs';”,但不能使用“import {Observable} from 'rxjs/Observable';”或“import {Observable} from 'rxjs/Rx';” (3认同)

Gio*_*osK 7

所有解决方案都不起作用,我不得不使用

import { Observable } from 'rxjs';
Run Code Online (Sandbox Code Playgroud)