Angular (6/7/8) - 在等待从window.location.assign加载内容时显示一个加载动画
创始人
2024-10-14 11:31:42
0

在Angular中,可以使用RxJS的Observable来实现在等待从window.location.assign加载内容时显示一个加载动画。下面是一个代码示例:

  1. 首先,需要安装RxJS库。可以通过运行以下命令来安装它:
npm install rxjs
  1. 在Angular组件中,引入所需的RxJS操作符和Observable:
import { Observable, interval, fromEvent } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
  1. 在组件类中创建一个方法,该方法将等待window.location.assign加载内容时显示加载动画。这个方法使用interval操作符来定期检查window.location.href是否已更改为新的URL,同时使用takeUntil操作符来停止循环检查:
showLoadingAnimation(): void {
  // 创建一个Observable,每500毫秒发出一个值
  const interval$ = interval(500);

  // 创建一个Observable,当window.location.href改变时发出一个值
  const change$ = new Observable(observer => {
    const handler = () => observer.next(window.location.href);
    fromEvent(window, 'click').subscribe(handler); // 监听click事件,当用户点击页面时发出一个值
    return () => window.removeEventListener('click', handler);
  });

  // 合并两个Observable,并在window.location.href改变时取消interval$
  interval$.pipe(takeUntil(change$)).subscribe(() => {
    // 显示加载动画的代码
    console.log('显示加载动画...');
  });
}
  1. 在组件的某个生命周期钩子中调用showLoadingAnimation方法,例如ngOnInit:
ngOnInit(): void {
  this.showLoadingAnimation();
}

现在,当组件加载时,它将定期检查window.location.href是否更改,并在等待加载新内容时显示加载动画。当用户点击页面时,interval将停止循环检查,加载动画也将停止显示。

相关内容

热门资讯

透视解迷!pokemmo辅助器... 透视解迷!pokemmo辅助器(透视)wepoker手机版辅助,教程绝活(有挂工具)-哔哩哔哩wep...
透视解迷!wepoker免费透... 透视解迷!wepoker免费透视(透视)wpk透视是真的吗,教程方针(有挂技巧)-哔哩哔哩1、全新机...
透视总结!hh poker透视... 透视总结!hh poker透视器下载(透视)fishpoker透视,教程演示(有挂神器)-哔哩哔哩1...
透视必备!wepoker祈福有... 透视必备!wepoker祈福有用吗(透视)wpk模拟器,教程方针(有挂神器)-哔哩哔哩1)wepok...
透视有挂!wepoker如何设... 透视有挂!wepoker如何设置透视(透视)wepoker可以开透视吗,教程讲义(有挂技术)-哔哩哔...
透视总结!wepoker免费辅... 透视总结!wepoker免费辅助器(透视)德普之星辅助工具如何打开,教程要领(有挂猫腻)-哔哩哔哩小...
透视解密!wepoker如何设... 透视解密!wepoker如何设置透视(透视)佛手在线大菠萝为什么都输,教程指南书(有人有挂)-哔哩哔...
透视开挂!wepoker有透视... 透视开挂!wepoker有透视底牌吗(透视)pokemmo脚本手机版,教程法子(有挂存在)-哔哩哔哩...
透视解密!wepoker有插件... 透视解密!wepoker有插件吗(透视)hhpoker破解工具,教程法门(有挂教学)-哔哩哔哩;1、...
透视曝光!pokemmo辅助器... 透视曝光!pokemmo辅助器脚本下载(透视)wepoker私人局怎么玩,教程模板(真的有挂)-哔哩...