通过内部的http.get

时间:2018-11-16 14:32:43

标签: javascript angular observable

我从角度开始。

我正在尝试创建一个Observable来加载和放入缓存数据。 我希望从我的应用程序的HomeComponent上预订此可观察的对象,当可观察的对象因为它完成而对其执行ping操作时,我将出现按钮

但是,我有一个问题  我有一个http.get从函数获取数据:charger_data()  然后,如果我成功获取了数据,我将对其进行转换并将其放入缓存

我想要我的主要功能:charger_data_et_cache()返回一个可观察的

我没有做到这一点,请你帮我! ?

谢谢

  public charger_data_et_cache(force:boolean) : Observable<boolean>{

    this.charger_data().subscribe(
      (value) => {
        console.log('Observable change ! => ' + value);
        charger_cache(value);
      },
      (error)=> {
        console.log('Observable error!');
      },
      () => {
        console.log('Observable complete!');
      }
    )
    
    
    return Observable.create( observer => {
        
    
    });

  
 }
 
 
 
 public charger_data():Observable<string>{
      return this.http.get('/assets/txt/mystere.txt',{responseType: 'text'}).pipe(
        map(data =>  {
          return data;
        }),catchError( error => {
          return throwError( 'error : ' + error )
        })
        );
  }
  
  
  public charger_cache(data:string){
  
    //do stuff
  }

1 个答案:

答案 0 :(得分:0)

我找到了!

public charger_data_et_cache(force:boolean) : Observable<boolean>{

    if(force == false && MystereService.mystere_charge){
      return Observable.create((observer) => observer.complete());
    }
    return this.charger_data(force).pipe(map(data => {
        this.charger_cache(data);
        console.log('charger_cache ok');
        return true;
    }),catchError( error => {
        return throwError( 'error' )
      }));

  }