Angular12:Resolve守卫重定向到其当前组件而不是导航到其目标
创始人
2024-10-21 22:01:15
0

在Angular 12中,Resolve守卫在重定向到其目标之前可以执行预先处理的逻辑,以确保需要的数据可用。在某些情况下,当Resolve守卫重定向到其目标时,可能会导致组件被重新加载,并且这并不是预期的行为。相反,我们希望它仅仅是让控制流在其原始组件中继续,同时确保需要的数据可用。

以下是一个示例,演示如何在Resolve守卫中实现这种行为:

import { Injectable } from '@angular/core';
import {
  Resolve,
  ActivatedRouteSnapshot,
  RouterStateSnapshot,
  Router,
} from '@angular/router';
import { Observable } from 'rxjs';
import { map, take } from 'rxjs/operators';
import { DataService } from './data.service';

@Injectable({
  providedIn: 'root'
})
export class MyResolveGuard implements Resolve {
  constructor(private dataService: DataService, private router: Router) {}

  resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable {
    const id = route.paramMap.get('id');

    return this.dataService.getData(id).pipe(
      take(1),
      map((data: any) => {
        if (!data) {
          // navigate to error page
          this.router.navigate(['/error']);
          return null;
        } else {
          return data;
        }
      })
    );
  }
}

在上面的代码中,我们首先获得了路由参数中的'id',然后使用数据服务从远程服务器中获取数据。

接下来,我们使用'take(1)'确保只获取一次数据,然后使用'map'操作符将数据转换为我们想要的格式。 如果数据不存在,我们将重定向到错误页面。

当Resolve守卫执行完毕后,控制流会返回到其原始组件,并确保

相关内容

热门资讯

透视游戏!wepoker私人辅... 透视游戏!wepoker私人辅助器(透视)陕西三代二辅助器(一贯存在有辅助安装)-哔哩哔哩1、用户打...
透视透视!菠萝辅助器免费版的特... 透视透视!菠萝辅助器免费版的特点(透视)金华佛手在线辅助软件(切实是有辅助工具)-哔哩哔哩运金华佛手...
透视美元局!德州局hhpoke... 透视美元局!德州局hhpoker(透视)新悠悠拼十辅助(本来真的有辅助软件)-哔哩哔哩1、操作简单,...
透视好牌!德普之星怎么设置埋牌... 透视好牌!德普之星怎么设置埋牌(透视)斗棋崇阳麻将辅助脚本(原来有辅助下载)-哔哩哔哩1、斗棋崇阳麻...
一直以来!hhpoker作必弊... 一直以来!hhpoker作必弊实战视频(透视)张同学俱乐部开挂系统(一贯是有辅助插件)-哔哩哔哩1、...
推出新举措!hhpoker辅助... 推出新举措!hhpoker辅助器(透视)五十k辅助(果然真的是有辅助平台)-哔哩哔哩1、进入游戏-大...
透视真的!德普软件(透视)多乐... 透视真的!德普软件(透视)多乐跑胡子辅助(竟然有辅助修改器)-哔哩哔哩;1、多乐跑胡子辅助破解器简单...
透视计算!wepoker俱乐部... 透视计算!wepoker俱乐部辅助(透视)逍遥湖北卡五星辅助器(其实真的是有辅助app)-哔哩哔哩1...
今天下午!智星德州插件(透视)... 今天下午!智星德州插件(透视)小闲川南辅助工具(其实是真的辅助下载)-哔哩哔哩今天下午!智星德州插件...
透视教程!wepoker插件下... 透视教程!wepoker插件下载(透视)情怀游戏字牌辅助(确实是真的辅助下载)-哔哩哔哩1、进入游戏...