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

相关内容

热门资讯

透视好牌!wpk脚本是什么,a... 透视好牌!wpk脚本是什么,aapoker透视脚本安装包,教学盘点(有挂总结);1、完成透视辅助安装...
wepower辅助器!wpk提... wepower辅助器!wpk提高胜率,(wepOke)其实真的有挂,解密教程(有挂辅助)1、下载好w...
透视辅助!wepoker底牌透... 透视辅助!wepoker底牌透视脚本app,aapoker透视脚本下载,交流学习经验(有挂攻略)1、...
德扑ai智能机器人!微扑克ai... 德扑ai智能机器人!微扑克ai辅助,(wepoKe)总是真的有挂,软件教程(有挂工具);1、进入到德...
透视线上!wpk透视辅助靠谱吗... 透视线上!wpk透视辅助靠谱吗,红龙poker有辅助吗,一分钟了解(有挂技巧)1、wpk透视辅助系统...
wepoke真的有挂!aapo... wepoke真的有挂!aapoker透视辅助,(wEPOKE)一直存在有挂,黑科技教程(有挂解说);...
透视能赢!aapoker透视插... 透视能赢!aapoker透视插件下载,红龙poker透视工具,必看攻略(有挂了解);1、起透看视 透...
德州之星外挂!智星德州菠萝外挂... 德州之星外挂!智星德州菠萝外挂,(wepOke)本来是有挂,靠谱教程(有挂规律);1、进入到智星德州...
透视了解!hhpoker免费透... 透视了解!hhpoker免费透视脚本,wpk辅助工具下载,记者揭秘(有挂详情)1、不需要AI权限,帮...
aapoker猫腻!德扑ai智... aapoker猫腻!德扑ai智能,(wepOke)总是有挂,分享教程(有挂工具)1、操作简单,无需注...