在Angular 7中,在更改路由之前加载图像,可以使用PreloadAllModules
加载所有模块,并在路由切换之前加载图像。下面是一个示例代码:
首先,确保你已经安装了@angular/router
和rxjs
依赖包。
在app.module.ts
文件中,导入PreloadAllModules
和RouterModule
模块,并在imports
数组中配置PreloadAllModules
:
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { RouterModule, PreloadAllModules } from '@angular/router';
import { AppComponent } from './app.component';
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
RouterModule.forRoot(routes, {
preloadingStrategy: PreloadAllModules
})
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
app.component.html
文件中,添加一个![]()
标签以加载图像:
app.component.ts
文件中,使用NavigationStart
事件监听路由的开始导航,并在处理事件时显示图像:import { Component } from '@angular/core';
import { Router, NavigationStart } from '@angular/router';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent {
showImage = false;
constructor(private router: Router) {
router.events.forEach((event) => {
if (event instanceof NavigationStart) {
this.showImage = true;
}
});
}
}
app.component.css
文件中,为图像添加CSS样式,以便在加载时可见:img {
display: block !important;
}
这样,当路由切换时,图像将在页面加载期间显示出来。