Angular中的Spinner在ngIf和router-outlet中无限循环。
创始人
2024-10-31 10:00:22
0

问题是由于ngIf指令造成的。ngIf指令是基于条件显示和隐藏DOM元素的,当表达式值为false时,元素被删除,当值变为true时,元素被添加。然而,当ngIf切换时,Angular会销毁并重建该元素的所有子组件,包括Spinner组件,这导致了无限循环。

解决方法是在spa-spinner组件的容器元素上绑定一个样式,并在引导应用程序时将此样式添加到head中。这将避免Angular重建此组件。例如,我们可以通过在index.html文件中添加以下代码来解决问题:


然后在app.component.ts中,将以下代码添加到app组件类中以显示或隐藏Spinner:

import { NavigationEnd, Router } from '@angular/router';
import { Component } from '@angular/core';

@Component({
  selector: 'app-root',
  template: `
    
`, }) export class AppComponent { constructor(private router: Router) { this.router.events.subscribe((event) => { if (event instanceof NavigationEnd) { const container = document.querySelector('.spinner-container'); container.setAttribute('style', 'display: none !important;'); } } }

这将确保仅在导航结束时才隐藏Spinner。现在,我们可以使用 ngSwitch 或 show-spinner directive 替换ngIf指令,并避免Angular重建Spinner组件。

相关内容

热门资讯

透视代打!hhpoker真的假... 透视代打!hhpoker真的假的(透视)一贯是有辅助app(有挂技巧)-哔哩哔哩1、实时hhpoke...
透视真的!约局吧游戏挂(透视)... 透视真的!约局吧游戏挂(透视)确实真的是有辅助辅助器(新版有挂)-哔哩哔哩1)约局吧游戏挂辅助插件:...
相较于以往!wepoker有用... 相较于以往!wepoker有用吗(透视)好像存在有辅助神器(有挂方针)-哔哩哔哩1、wepoker有...
外挂手段!xpoker怎么作必... 外挂手段!xpoker怎么作必弊,werplan免费挂下载-切实一直都是有辅助工具(哔哩哔哩)1、上...
今日!云扑克有透视吗(透视)真... 今日!云扑克有透视吗(透视)真是有辅助软件(有挂攻略)-哔哩哔哩暗藏猫腻,小编详细说明云扑克有透视吗...
外挂手段!德州透视是真的吗,哈... 外挂手段!德州透视是真的吗,哈糖大菠萝助手-一直是真的有辅助攻略(哔哩哔哩)1、德州透视是真的吗破解...
透视科技!epoker免费透视... 透视科技!epoker免费透视脚本(透视)都是是有辅助下载(有挂助手)-哔哩哔哩一、epoker免费...
外挂窍要!德普之星私人局透视,... 外挂窍要!德普之星私人局透视,德州之星扫描器-总是有辅助技巧(哔哩哔哩)一、德州之星扫描器游戏安装教...
透视软件!wepoker有什么... 透视软件!wepoker有什么规律(透视)其实真的是有辅助辅助器(揭秘有挂)-哔哩哔哩1、wepok...
经调查!hhpoker作必弊码... 经调查!hhpoker作必弊码(透视)一贯有辅助神器(存在有挂)-哔哩哔哩1、玩家可以在hhpoke...