首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >避免重复的api调用angular2

避免重复的api调用angular2
EN

Stack Overflow用户
提问于 2017-03-09 11:14:15
回答 1查看 3.5K关注 0票数 0

我有一个对类别的api调用,一切都很好。现在,如果我需要在另一个页面中的类别,它再次调用,而我需要在本地存储它。我只是遵循了我在angular1中练习的方法,但是它的抛出错误。评论的台词是我的考验。

代码语言:javascript
复制
private categories: any;
  constructor(private http: Http) { }

  getCategories(): Promise<any> {
    // if(!this.categories){
    return this.http.get(environment.API_ENDPOINT + 'categories')
      .toPromise()
      .then(this.extractData)
      .catch(this.handleError);
    // }else{
    //   console.log("call blocked");
    //   return Promise.resolve(this.categories);
    // }

  }


  private extractData(res: Response) {
    let body = res.json();
    //  this.categories = body || [];
    return body;
    //return this.categories;
  }

  private handleError(error: any): Promise<any> {

    return Promise.reject(JSON.parse(error.message || error._body || error));
  }

如何存储api接收到的数据,因此我调用服务,它将检查以前的数据,如果不可用,它将从服务器获取数据。

提前谢谢。

尝试用可观察和的方法

代码语言:javascript
复制
import { Injectable } from '@angular/core';

import { Http, Response } from '@angular/http';
import { Observable } from 'rxjs/Observable';
import 'rxjs/add/observable/of'; //updating import library, which threw error
import 'rxjs/add/operator/catch';
import 'rxjs/add/operator/share';
import 'rxjs/add/operator/map';
import 'rxjs/add/operator/publishReplay'
import {Cities} from '../interface/cities';
import { environment } from '../../environments/environment';
@Injectable()
export class CityService {
  private endPoint = environment.API_URL+'cities';
  private data:any;
  constructor(
    private http: Http) { }

   getAll (): Observable<Cities[]> {
     if(this.data){
        return Observable.of(this.data); // 
      }
    return this.http.get(this.endPoint)
                    .map(this.extractData)
                    .catch(this.handleError);
  }
  private extractData(res: Response) {
    let body = res.json();
    this.data = body || body.data || { };
    return this.data;
  }
  private handleError (error: Response | any) {
    // In a real world app, we might use a remote logging infrastructure
    let errMsg: string;
    if (error instanceof Response) {
      const body = error.json() || '';
      const err = body.error || JSON.stringify(body);
      errMsg = `${error.status} - ${error.statusText || ''} ${err}`;
    } else {
      errMsg = error.message ? error.message : error.toString();
    }
    console.error(errMsg);
    return Observable.throw(errMsg);
  }

}

尝试了发布计数

代码语言:javascript
复制
import { Injectable } from '@angular/core';

import { Http, Response } from '@angular/http';
import { Observable } from 'rxjs/Observable';
import 'rxjs/observable/of';
import 'rxjs/add/operator/catch';
import 'rxjs/add/operator/share';
import 'rxjs/add/operator/map';
import 'rxjs/add/operator/publishReplay'
import {Cities} from '../interface/cities';
import { environment } from '../../environments/environment';
@Injectable()
export class CityService {
  private endPoint = environment.API_URL+'cities';
  private data:any;
  constructor(
    private http: Http) { }

   getAll (): Observable<Cities[]> {
    return this.http.get(this.endPoint)
                    .map(this.extractData)
                    .publishReplay(1) // does not stop duplicate calls
                    .refCount() // does not stop duplicate calls
                    .catch(this.handleError);
  }
  private extractData(res: Response) {
    let body = res.json();
    this.data = body || body.data || { };
    return this.data;
  }
  private handleError (error: Response | any) {
    // In a real world app, we might use a remote logging infrastructure
    let errMsg: string;
    if (error instanceof Response) {
      const body = error.json() || '';
      const err = body.error || JSON.stringify(body);
      errMsg = `${error.status} - ${error.statusText || ''} ${err}`;
    } else {
      errMsg = error.message ? error.message : error.toString();
    }
    console.error(errMsg);
    return Observable.throw(errMsg);
  }

}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-03-16 18:01:03

最后,经过两天的斗争,我发现这只是我的工作解决方案。

虽然我向城市发布了一个问题,但这是关于类别的问题。

代码语言:javascript
复制
import { Injectable } from '@angular/core';

import { Http, Response } from '@angular/http';
import { Observable } from 'rxjs/Observable';
import 'rxjs/add/observable/of';
import 'rxjs/add/operator/catch';
import 'rxjs/add/operator/share';
import 'rxjs/add/operator/map';
import { Cities } from '../interface/cities';
import { environment } from '../../environments/environment';
import { LocalStorageService } from 'angular-2-local-storage';
@Injectable()
export class CityService {
  private endPoint = environment.API_URL + 'cities';
  private data: any;
  constructor(
    private http: Http,
    private localStorageService: LocalStorageService) { }

  getAll(): Observable<Cities[]> {
    if (this.localStorageService.get('cities')) {
      return Observable.of(this.localStorageService.get('cities'));
    } else {
      return this.http.get(this.endPoint)
        .map(this.extractData)
        .do((data) => this.localStorageService.set("cities", data))
        .catch(this.handleError);
    }
  }
  private extractData(res: Response) {
    let body = res.json();
    this.data = body || body.data || {};

    //this.localStorage.setItems$.subscribe("cities", "Hello world");
    return this.data;
  }
  private handleError(error: Response | any) {
    // In a real world app, we might use a remote logging infrastructure
    let errMsg: string;
    if (error instanceof Response) {
      const body = error.json() || '';
      const err = body.error || JSON.stringify(body);
      errMsg = `${error.status} - ${error.statusText || ''} ${err}`;
    } else {
      errMsg = error.message ? error.message : error.toString();
    }
    console.error(errMsg);
    return Observable.throw(errMsg);
  }

}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42693897

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档