Angular HTTP GET with TypeScript error http.get(…).map is not a function in [null]

前端 未结 19 2493
时光取名叫无心
时光取名叫无心 2020-11-22 03:36

I have a problem with HTTP in Angular.

I just want to GET a JSON list and show it in the view.

Service class

im         


        
19条回答
  •  误落风尘
    2020-11-22 04:13

    From rxjs 5.5 onwards, you can use the pipeable operators

    import { map } from 'rxjs/operators';
    

    What is wrong with the import 'rxjs/add/operator/map';

    When we use this approach map operator will be patched to observable.prototype and becomes a part of this object.

    If later on, you decide to remove map operator from the code that handles the observable stream but fail to remove the corresponding import statement, the code that implements map remains a part of the Observable.prototype.

    When the bundlers tries to eliminate the unused code (a.k.a. tree shaking), they may decide to keep the code of the map operator in the Observable even though it’s not being used in the application.

    Solution - Pipeable operators

    Pipeable operators are pure functions and do not patch the Observable. You can import operators using the ES6 import syntax import { map } from "rxjs/operators" and then wrap them into a function pipe() that takes a variable number of parameters, i.e. chainable operators.

    Something like this:

    getHalls() {
        return this.http.get(HallService.PATH + 'hall.json')
        .pipe(
            map((res: Response) => res.json())
        );
    }
    

提交回复
热议问题