Angular 6中的http.get订阅获取相同数据而不查询api。
创始人
2024-10-16 10:30:38
0

要在Angular 6中使用http.get获取相同的数据而不需要每次都查询API,可以使用RxJS的缓存操作符。以下是一个示例解决方法:

  1. 首先,导入所需的模块和操作符:
import { HttpClient } from '@angular/common/http';
import { Observable, of } from 'rxjs';
import { map, shareReplay } from 'rxjs/operators';
  1. 在你的服务中定义一个私有变量来存储缓存的数据:
private cachedData: Observable;
  1. 创建一个方法来获取数据。在这个方法中,使用shareReplay操作符来缓存数据,并使用map操作符将响应转换为你需要的格式:
getData(): Observable {
  if (!this.cachedData) {
    this.cachedData = this.http.get('your-api-url').pipe(
      map(response => {
        // 对响应进行转换
        // 例如,如果响应是一个对象数组,你可以使用下面的代码来转换为一个简单的数组:
        return response.map(item => item.name);
      }),
      shareReplay(1) // 缓存最近的1个响应
    );
  }
  return this.cachedData;
}
  1. 在使用该服务的组件中,只需调用getData方法来获取数据即可:
getData(): void {
  this.service.getData().subscribe(data => {
    // 使用缓存的数据
    console.log(data);
  });
}

通过这种方式,第一次调用getData方法时,数据将会从API中获取并缓存起来。随后的调用将直接从缓存中获取数据,而不会再次查询API。

相关内容

热门资讯

备受关注的!打哈儿床将辅助,确... 备受关注的!打哈儿床将辅助,确实存在有辅助插件(有挂教学)-哔哩哔哩打哈儿床将辅助脚本下载中分为三种...
据相关数据显示!全托中至窝龙拿... 据相关数据显示!全托中至窝龙拿好牌,真是真的有辅助工具(详细教程)-哔哩哔哩1、每一步都需要思考,不...
现场直击!雀神麻雀充运势用吗,... 现场直击!雀神麻雀充运势用吗,本来存在有辅助脚本(有挂攻略)-哔哩哔哩1、这是跨平台的雀神麻雀充运势...
有消息称!闲逸亲友圈app辅助... 有消息称!闲逸亲友圈app辅助,原来是真的辅助神器(有挂技术)-哔哩哔哩亲,关键说明,闲逸亲友圈ap...
一直以来!广西老友玩有破解吗,... 一直以来!广西老友玩有破解吗,都是是真的辅助平台(确实有挂)-哔哩哔哩一直以来!广西老友玩有破解吗,...
据统计!天天微友辅助神器,竟然... 据统计!天天微友辅助神器,竟然有挂辅助app(详细教程)-哔哩哔哩一、天天微友辅助神器游戏安装教程牌...
据文件显示!兴动互娱软件辅助下... 据文件显示!兴动互娱软件辅助下载,切实真的是有辅助下载(有挂分享)-哔哩哔哩1、让任何用户在无需兴动...
据监测!边锋老友威海荣成辅助,... 您好,边锋老友威海荣成辅助这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054】很...
目前!小唐家乐园辅助器下载链接... 目前!小唐家乐园辅助器下载链接,真是真的有辅助平台(有挂方略)-哔哩哔哩小唐家乐园辅助器下载链接脚本...
近年来!美猴王大厅怎么修改数据... 近年来!美猴王大厅怎么修改数据,一贯真的有辅助插件(新版有挂)-哔哩哔哩一、美猴王大厅怎么修改数据可...