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

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

相关内容

热门资讯

透视插件!wepoker游戏的... 透视插件!wepoker游戏的安装教程,先前是有挂(透视)攻略方法(有挂揭秘)1、游戏颠覆性的策略玩...
透视科技!werplan怎么透... 透视科技!werplan怎么透视,好像存在有挂(透视)必胜教程(有挂介绍);1、透视科技!werpl...
透视好友房!hhpoker软件... 透视好友房!hhpoker软件靠谱吗,从前是真的有挂(透视)规律教程(有挂揭秘)hhpoker软件靠...
透视有挂!wpk透视是真的假的... 透视有挂!wpk透视是真的假的,原本真的有挂(透视)必赢方法(有挂解密)1、进入到wpk透视是真的假...
透视黑科技!wepoker免费... 透视黑科技!wepoker免费脚本咨询,总是真的是有挂(透视)实用技巧(有挂攻略)1、wepoker...
透视科技!wepoker私人局... 透视科技!wepoker私人局有透视吗,确实真的是有挂(透视)必备教程(有挂插件)1、wepoker...
透视好友房!hhpoker是正... 透视好友房!hhpoker是正规的吗,原先存在有挂(透视)wpk教程(有挂解密);1、hhpoker...
透视安装!wepoker辅助透... 透视安装!wepoker辅助透视软件,本然真的有挂(透视)教你攻略(有挂脚本);1、实时wepoke...
透视神器!wepoker透视脚... 透视神器!wepoker透视脚本免费app,固有真的是有挂(透视)科技教程(有挂解密)1、这是跨平台...
辅助透视!wepoker有透视... 辅助透视!wepoker有透视底牌吗,固有存在有挂(透视)可靠技巧(有挂黑科技)1.wepoker有...