Angular中的Authguard弹出窗口被浏览器阻止
创始人
2024-10-31 02:30:20
0

在调用弹出窗口的地方添加用户事件(比如监听点击事件),然后在回调函数中打开弹出窗口。这样浏览器就不会将其视为无效弹出窗口。

示例代码:

import { Injectable } from '@angular/core';
import { CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot, UrlTree, Router } from '@angular/router';
import { Observable } from 'rxjs';

@Injectable({
  providedIn: 'root'
})
export class AuthGuard implements CanActivate {
  constructor(private router: Router) {}
  
  canActivate(
    next: ActivatedRouteSnapshot,
    state: RouterStateSnapshot): Observable | Promise | boolean | UrlTree {
  
    return this.checkLogin().then((isLoggedIn) => {
      if (isLoggedIn) {
        return true;
      } else {
        // 添加用户事件
        document.addEventListener('click', () => {
          // 在回调函数中打开弹出窗口
          window.open('https://example.com/login');
        });
  
        return false;
      }
    });
  }

  checkLogin(): Promise {
    // 实现登录判断逻辑
  }
}

注意:这种解法并不是在所有浏览器中都适用,因为一些浏览器可能对用户事件也进行拦截。对于这种情况,最好的解决方案是不要使用弹出窗口,而是使用模态框或其他交互组件。

相关内容

热门资讯

黑科技私人局(wpk线上)外挂... 黑科技私人局(wpk线上)外挂透视辅助挂(透视)详细教程(好像有挂)1.wpk线上 ai辅助创建新账...
黑科技有挂(WepOke)黑科... 黑科技有挂(WepOke)黑科技透明挂辅助插件(透视)扑克教程(真是真的有挂);1、WepOke透视...
黑科技安卓版(wepokE)黑... 黑科技安卓版(wepokE)黑科技透明挂辅助器(透视)大神讲解(切实是真的有挂);1、超多福利:超高...
黑科技教程(wpK)外挂透视辅... 黑科技教程(wpK)外挂透视辅助教程(透视)2025新版教程(都是是有挂)1)wpK辅助挂:进一步探...
黑科技模拟器(wpk线上)外挂... 黑科技模拟器(wpk线上)外挂透视辅助插件(透视)AI教程(切实是有挂)1、wpk线上机器人多个强度...
黑科技挂(wEpoke)黑科技... 黑科技挂(wEpoke)黑科技透明挂辅助方法(透视)攻略教程(竟然是有挂)wEpoke软件透明挂微扑...
黑科技规律(wpk微扑克)外挂... 黑科技规律(wpk微扑克)外挂透视辅助技巧(透视)新2025教程(一贯是有挂)1、许多玩家不知道wp...
黑科技辅助挂(微扑克小程序)外... 黑科技辅助挂(微扑克小程序)外挂透视辅助安装(透视)插件教程(确实真的是有挂)1、每一步都需要思考,...
黑科技科技(wpK)外挂透视辅... 黑科技科技(wpK)外挂透视辅助器(透视)AI教程(总是是真的有挂);1、实时wpK开挂更新:用户可...
黑科技ai(wepoKe)黑科... 黑科技ai(wepoKe)黑科技透明挂辅助安装(透视)透明教程(真是真的有挂);1、wepoKeai...