在 Angular 2 中的路线更改期间显示加载屏幕
在 Angular 2 中,在路线之间导航可以触发加载屏幕的显示,提供应用程序正在运行的视觉指示
使用导航事件
Angular Router 提供了跟踪路线更改进度的导航事件。通过订阅这些事件,您可以相应地操作 UI,包括显示加载屏幕。操作方法如下:
app.component.ts(根组件)
import { Router, Event as RouterEvent, NavigationStart, NavigationEnd, NavigationCancel, NavigationError } from '@angular/router'; @Component({/* ... */}) export class AppComponent { // Initialize loading indicator loading = true; constructor(private router: Router) { router.events.subscribe((e: RouterEvent) => this.navigationInterceptor(e)); } navigationInterceptor(event: RouterEvent): void { if (event instanceof NavigationStart) { this.loading = true; } if (event instanceof NavigationEnd) { this.loading = false; } if (event instanceof NavigationCancel || event instanceof NavigationError) { this.loading = false; } } }
app.component.html(根视图)
<div class="loading-overlay"> <!-- Show loading animation, e.g., spinner --> </div>
性能增强
为了提高性能,请利用 Angular 的 NgZone 和 Renderer 来控制加载屏幕的可见性。这会绕过更改检测,从而实现更平滑的动画过渡:
app.component.ts(更新的根组件)
import { NgZone, Renderer, ElementRef, ViewChild } from '@angular/core'; @Component({/* ... */}) export class AppComponent { @ViewChild('spinnerElement') spinnerElement: ElementRef; constructor(private ngZone: NgZone, private renderer: Renderer, private router: Router) { router.events.subscribe(this._navigationInterceptor); } private _navigationInterceptor(event: RouterEvent): void { if (event instanceof NavigationStart) { this.ngZone.runOutsideAngular(() => { this.renderer.setElementStyle( this.spinnerElement.nativeElement, 'opacity', '1' ); }); } if (event instanceof NavigationEnd) { this._hideSpinner(); } if (event instanceof NavigationCancel || event instanceof NavigationError) { this._hideSpinner(); } } private _hideSpinner(): void { this.ngZone.runOutsideAngular(() => { this.renderer.setElementStyle( this.spinnerElement.nativeElement, 'opacity', '0' ); }); } }
app.component.html (更新的根视图)
<div class="loading-overlay"><p>通过实施这些技术,您可以在 Angular 2 中的路线导航期间有效管理加载屏幕的可见性,通过清晰的视觉反馈增强用户体验。</p></div>
以上是如何在 Angular 2 中的路线更改期间显示加载屏幕?的详细内容。更多信息请关注PHP中文网其他相关文章!

这是我们在形式可访问性上进行的小型系列中的第三篇文章。如果您错过了第二篇文章,请查看“以:focus-visible的管理用户焦点”。在

本教程演示了使用智能表单框架创建外观专业的JavaScript表单(注意:不再可用)。 尽管框架本身不可用,但原理和技术仍然与其他形式的建筑商相关。

CSS盒子阴影和轮廓属性获得了主题。让我们查看一些在真实主题中起作用的示例,以及我们必须将这些样式应用于WordPress块和元素的选项。

Svelte Transition API提供了一种使组件输入或离开文档(包括自定义Svelte Transitions)时动画组件的方法。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Atom编辑器mac版下载
最流行的的开源编辑器

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器