Angular 6+ Universal只预加载特定的路由。
创始人
2024-10-16 04:30:06
0

要实现Angular 6+ Universal只预加载特定路由的功能,可以按照以下步骤进行操作:

  1. 在Angular项目中安装Angular Universal依赖:
npm install @angular/platform-server @nguniversal/module-map-ngfactory-loader ts-loader --save
  1. app.module.ts文件中导入ServerModuleModuleMapLoaderModule模块:
import { NgModule } from '@angular/core';
import { ServerModule } from '@angular/platform-server';
import { ModuleMapLoaderModule } from '@nguniversal/module-map-ngfactory-loader';

import { AppModule } from './app.module';
import { AppComponent } from './app.component';

@NgModule({
  imports: [
    AppModule,
    ServerModule,
    ModuleMapLoaderModule
  ],
  bootstrap: [AppComponent],
})
export class AppServerModule { }
  1. app-routing.module.ts文件中定义需要预加载的路由:
import { NgModule } from '@angular/core';
import { Routes, RouterModule, PreloadAllModules } from '@angular/router';

const routes: Routes = [
  { path: 'home', loadChildren: './home/home.module#HomeModule' },
  { path: 'about', loadChildren: './about/about.module#AboutModule', data: { preload: true } },
  { path: 'contact', loadChildren: './contact/contact.module#ContactModule', data: { preload: true } },
];

@NgModule({
  imports: [RouterModule.forRoot(routes, {
    preloadingStrategy: CustomPreloadingStrategy // 自定义预加载策略
  })],
  exports: [RouterModule]
})
export class AppRoutingModule { }
  1. 创建一个名为custom-preloading-strategy.ts的文件,并定义自定义预加载策略:
import { Injectable } from '@angular/core';
import { PreloadingStrategy, Route } from '@angular/router';
import { Observable, of } from 'rxjs';

@Injectable()
export class CustomPreloadingStrategy implements PreloadingStrategy {
  preload(route: Route, load: () => Observable): Observable {
    if (route.data && route.data.preload) {
      return load();
    } else {
      return of(null);
    }
  }
}
  1. app.module.ts文件中将自定义预加载策略提供给应用程序:
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppRoutingModule } from './app-routing.module';
import { AppComponent } from './app.component';
import { CustomPreloadingStrategy } from './custom-preloading-strategy';

@NgModule({
  imports: [
    BrowserModule,
    AppRoutingModule
  ],
  declarations: [AppComponent],
  providers: [CustomPreloadingStrategy], // 提供自定义预加载策略
  bootstrap: [AppComponent]
})
export class AppModule { }

通过以上步骤,你可以设置data: { preload: true }来指定需要预加载的路由,其他路由将按需加载。

相关内容

热门资讯

发现玩家!德普之星辅助器,we... 1、发现玩家!德普之星辅助器,wepoker手机插件,曝光教程(有挂技巧);详细教程。2、德普之星辅...
一起来讨论!德州局透视脚本免费... 一起来讨论!德州局透视脚本免费版下载手机版,wepoker私人局俱乐部,AA德州教程(有挂技巧);致...
技术分享!we poker辅助... 技术分享!we poker辅助器v3.3,aapoker ai插件,详细教程(有挂攻略);亲真的是有...
实测必看!wepoker智能辅... 实测必看!wepoker智能辅助插件,wepoker轻量版透视系统,我来教教你(有挂神器);原来确实...
玩家必看!wepoker私人局... 玩家必看!wepoker私人局外卦,wepoker怎么设置透视,可靠技巧(有挂攻略)是一款可以让一直...
实测发现!wepoker免费透... 实测发现!wepoker免费透视,pokemomo辅助软件,攻略教程(有挂软件)1、点击下载安装,微...
让我来分享经验!wepoker... 让我来分享经验!wepoker智能辅助插件,wepoker辅助透视,曝光教程(有挂方法);《WPK辅...
科普!aapoker插件,we... 科普!aapoker插件,wepoker辅助软件视频,安装教程(有挂透明);支持多人共享记分板与复盘...
必知教程!wepoker好友助... 必知教程!wepoker好友助力码,aapoker透视怎么用,AA德州教程(有挂技巧)准备好在aap...
技术分享!德州透视hhpoke... 技术分享!德州透视hhpoker,拱趴大菠萝十三水作弊,黑科技教程(有挂透明);最新版2024是一款...