angular路由守卫的break down2

复制代码
canActivate(route: ActivatedRouteSnapshot,
    state: RouterStateSnapshot): Observable<boolean> | Promise<boolean> | boolean {

    this.editonRenewalService.getPayMaintenance({ accountId: 0 }).subscribe(
      res => {
        if (res.code === 200 && res.result === false) {
          return true;
        } else {
          this.router.navigate(["/notice", { value: 0 }]);
          return false;
        }
      },
      error => {
        console.error(error);
        this.router.navigate(["/notice", { value:0 }]);
        return false;
      }
    );

  }

问题分析

  1. 返回值问题

    • canActivate 方法需要明确返回一个值,但你的代码中 subscribe 是一个异步操作,它不会返回任何值给 canActivate 方法。

    • subscribe 的回调中返回 truefalse 是无效的,因为这些值不会被 canActivate 方法捕获。

  2. 异步处理问题

    • subscribe 是 RxJS 的订阅操作,用于处理 Observable 的值,但它不会返回一个 Observable 或 Promise。

    • 如果你需要在 canActivate 中处理异步逻辑,应该直接返回一个 Observable 或 Promise。

合理示例

复制代码
canActivate(
  route: ActivatedRouteSnapshot,
  state: RouterStateSnapshot
): Observable<boolean> {
  return this.editonRenewalService.getPayMaintenance({ accountId: 0 }).pipe(
    map((res) => {
      if (res.code === 200 && res.result === false) {
        return true; // 允许访问
      } else {
        this.router.navigate(['/notice', { value: 0 }]);
        return false; // 不允许访问
      }
    }),
    catchError((error) => {
      console.error(error);
      this.router.navigate(['/notice', { value: 0 }]);
      return of(false); // 返回一个 Observable,值为 false
    })
  );
}

map 操作符的作用

map 是一个 RxJS 操作符,用于对 Observable 的值进行转换。它会接收一个函数,该函数对每个值进行处理,并返回一个新的值。

  • map 的回调函数 :这里的回调函数接收 res,并对它进行处理。

  • 逻辑判断 :根据 res.coderes.result 的值,返回一个布尔值:

    • 如果 res.code === 200 && res.result === false,返回 true

    • 否则,返回 false

  • 返回值map 操作符会将原始 Observable 的值转换为布尔值,最终返回一个 Observable<boolean>

catchError 操作符的作用

catchError 是一个 RxJS 操作符,用于捕获 Observable 中的错误,并返回一个新的 Observable。

相关推荐
八戒社2 分钟前
如何使用插件和子主题添加WordPress自定义CSS(附:常见错误)
前端·css·tensorflow·wordpress
xzboss14 分钟前
DOM转矢量PDF
前端·javascript
一无所有不好吗14 分钟前
纯前端vue项目实现版本更新(纯代码教程)
前端
萌萌哒草头将军16 分钟前
🏖️ 舒服,原来写代码还可以这么享受😎!沉浸式敲代码神器!
javascript·vue.js·react.js
安全系统学习28 分钟前
内网横向之RDP缓存利用
前端·安全·web安全·网络安全·中间件
Hilaku35 分钟前
为什么我不再相信 Tailwind?三个月重构项目教会我的事
前端·css·前端框架
waterHBO35 分钟前
改写自己的浏览器插件工具 myChromeTools
javascript
FogLetter36 分钟前
JavaScript 的历史:从网页点缀到改变世界的编程语言
前端·javascript·http
鹏北海38 分钟前
Vue3+TS的H5项目实现微信分享卡片样式
前端·微信
轻颂呀40 分钟前
进程——环境变量及程序地址空间
前端·chrome