Angular路由解析器执行两次
创始人
2024-10-28 02:00:41
0

在定义路由时,可以通过在路由上加上一个 resolve 属性来实现路由的解析及数据预加载。但是有时候,Angular 路由解析器似乎会执行两次,这会导致性能问题。解决这个问题的方法是使用 rxjs 的操作符来处理。

假设我们有这样一个路由:

const routes: Routes = [
  {
    path: 'items',
    component: ItemsComponent,
    resolve: {
      items: ItemsResolver
    }
  }
];

其中,ItemsResolver 是一个从远程 API 获取数据的解析器。如果路由解析器执行两次,那么在控制台中将会看到两次 ItemsResolver 的输出。

为了解决这个问题,我们可以使用 rxjs 的 shareReplay 操作符来缓存 API 的响应。如下所示:

@Injectable({
  providedIn: 'root'
})
export class ItemsResolver implements Resolve {
  constructor(private httpClient: HttpClient) {}

  resolve() {
    return this.httpClient.get('https://api.example.com/items').pipe(shareReplay());
  }
}

这里使用了 shareReplay 操作符,它会把请求的响应保存在一个缓存流中,以便之后的订阅也可以共享这个缓存流中的数据。这个操作符会把已经发射过的数据缓存起来,并将缓存中的最后一个值交给新订阅者。这样就可以避免路由解析器重复执行 ItemsResolver

相关内容

热门资讯

终于知道!佛手在线辅助器,微乐... 终于知道!佛手在线辅助器,微乐贵阳麻将辅助,详细教程(有人有挂)是一款可以让一直输的玩家,快速成为一...
一分钟揭秘!新祥心辅助脚本,新... 一分钟揭秘!新祥心辅助脚本,新西游大厅辅助,透牌教程(有挂分享);大家肯定在之前新西游大厅辅助或者新...
热点讨论!福州天天开心辅助,天... 热点讨论!福州天天开心辅助,天天贵阳游戏辅助,分享教程(有挂分享),天天贵阳游戏辅助是用手机号来登录...
揭秘一下!九游辅助辅助在哪里,... 揭秘一下!九游辅助辅助在哪里,新财神正版辅助挂,曝光教程(有挂总结);1、在九游辅助辅助在哪里ai机...
技术分享!微信小程序辅助器免费... 技术分享!微信小程序辅助器免费,科乐天天踢填大坑游戏攻略,详细教程(有挂细节);1、德州科乐天天踢填...
今日科普!赖子三加一辅助,新九... 今日科普!赖子三加一辅助,新九五辅助,黑科技教程(有挂猫腻)是一款可以让一直输的玩家,快速成为一个“...
今日公布!新道游正版作弊微信辅... 今日公布!新道游正版作弊微信辅助,如何做方片十三张脚本,wpk教程(果真有挂);超受欢迎的新道游正版...
新手必备!新518互游脚本,新... 新手必备!新518互游脚本,新鸿狐挂机,黑科技教程(确实有挂);1.新518互游脚本 ai辅助创建新...
重大通报!手机奇迹辅助工具,圣... 重大通报!手机奇迹辅助工具,圣盛荆州晃晃辅助工具,解密教程(有挂技术)是一款可以让一直输的玩家,快速...
必备攻略!天酷辅助巡查系统,新... 必备攻略!天酷辅助巡查系统,新祥心挂机,大神讲解(真的有挂);大家肯定在之前天酷辅助巡查系统或者天酷...