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 {
    // 实现登录判断逻辑
  }
}

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

相关内容

热门资讯

7分钟了解(wpk修改器)软件... 7分钟了解(wpk修改器)软件透明挂辅助器(透视)2025教程(2021已更新)(哔哩哔哩);1、点...
三分钟了解(AAPOkER)黑... 三分钟了解(AAPOkER)黑科技透明挂辅助工具(透视)玩家教程(2020已更新)(哔哩哔哩)相信很...
8分钟了解(aapOker)软... 8分钟了解(aapOker)软件透明挂辅助软件(透视)细节方法(2024已更新)(哔哩哔哩)是一款可...
七分钟了解(WepOke)外挂... 七分钟了解(WepOke)外挂辅助插件安装挂(透视)科技教程(2024已更新)(哔哩哔哩);WepO...
5分钟了解(微扑克有挂)软件透... 5分钟了解(微扑克有挂)软件透明挂辅助安装(透视)技巧教程(2020已更新)(哔哩哔哩);1、超多福...
9分钟了解(aapoker开发... 9分钟了解(aapoker开发)软件透明挂辅助科技(透视)总结教程(2026已更新)(哔哩哔哩);相...
2分钟了解(聚星扑克)软件透明... 2分钟了解(聚星扑克)软件透明挂辅助神器(透视)辅助教程(2024已更新)(哔哩哔哩)是一款可以让一...
第九分钟了解(We辅poker... 第九分钟了解(We辅poker助)黑科技透明挂辅助插件(透视)专业教程(2024已更新)(哔哩哔哩)...
第五分钟了解(wEpoKe)软... 第五分钟了解(wEpoKe)软件透明挂辅助科技(透视)切实教程(2021已更新)(哔哩哔哩);AI辅...
4分钟了解(wepokeai代... 4分钟了解(wepokeai代打)外挂透明挂辅助神器(透视)爆料教程(2026已更新)(哔哩哔哩);...