Advanced Routing @Angular Days 2020 Berlin/Online

Advanced Routing @Angular Days 2020 Berlin/Online

15934fa2aa7b2ce21f091e9b7cffa856?s=128

Manfred Steyer

October 07, 2020
Tweet

Transcript

  1. Advanced Routing Manfred Steyer SOFTWAREarchitekt.at ManfredSteyer

  2. Routen sind der Dreh- und Angelpunkt Ihrer Angular-Anwendung!

  3. Inhalt • Basics: Kurze Wiederholung • Hierarchisches Routing • Aux

    Routes • Guards • Resolver • Router Events • Lazy Loading und Preloading Page ▪ 3
  4. Über mich • Manfred Steyer SOFTWAREarchitekt.at • Angular Trainings and

    Consultancy • Google Developer Expert (GDE) • Trusted Collaborator for Angular Page ▪ 4 Manfred Steyer Remote or In-House http://www.softwarearchitekt.at/workshops
  5. Routing in Angular Page ▪ 5 Logo + Menü Menü

    2 Fußzeile SPA Platzhalter
  6. Routing in Angular Page ▪ 6 Logo + Menü Menü

    2 Fußzeile SPA Passagier- Komponente /FlugDemo/passagier
  7. Konfiguration Page ▪ 12 const APP_ROUTES: Routes = [ {

    path: 'home', component: HomeComponent }, { path: 'flug-suchen', component: FlugSuchenComponent } ]
  8. Konfiguration Page ▪ 15 // app.module.ts @NgModule({ imports: [ BrowserModule,

    HttpModule, FormsModule, RouterModule.forRoot(APP_ROUTES); ], […] }) export class AppModule { } Für Root-Module Für Feature-Module: forChild
  9. View von AppComponent Page ▪ 18 <a routerLink="/home">Home</a> <a routerLink="/flug-suchen">Flug

    suchen</a> <div> <router-outlet></router-outlet> </div>
  10. DEMO Page ▪ 25

  11. Hierarchisches Routing Page ▪ 26

  12. Hierarchische Views Page ▪ 27 Logo + Menü Menü 2

    Fußzeile SPA Platzhalter 1
  13. Hierarchische Views Page ▪ 28 Logo + Menü Menü 2

    Fußzeile SPA /FlugDemo/flugbuchen FlugBuchen-Komponente
  14. Hierarchische Views Page ▪ 29 Logo + Menü Menü 2

    Fußzeile SPA Optionen Platzhalter FlugBuchen-Komponente /FlugDemo/flugbuchen
  15. Hierarchische Views Page ▪ 30 Logo + Menü Menü 2

    Fußzeile SPA Optionen Passagier- Komponente FlugBuchen-Komponente /FlugDemo/flugbuchen/passagier
  16. Konfiguration Page ▪ 31 const APP_ROUTES: Routes = [ {

    path: 'flug-buchen', component: FlugBuchenComponent, children: [ { path: 'flug-suchen', component: FlugSuchenComponent }, […] ] } ];
  17. DEMO Page ▪ 32 App Home Flug buchen Flug suchen

    Flug editieren Passagier suchen Ihre Buchungen
  18. Aux-Routes Page ▪ 35

  19. Aux-Routes Page ▪ 36 Logo + Menu Menu 2 Footer

    SPA Placeholder Named Placeholder
  20. Aux-Routes Page ▪ 37 Logo + Menu Menu 2 Footer

    SPA Flight- Component Named Placeholder /FlightApp/flights
  21. Aux-Routes Page ▪ 38 Logo + Menu Menu 2 Footer

    SPA Flight- Component Info-Component /FlightApp/flights(aux:info)
  22. Aux-Routes Page ▪ 39 Logo + Menu Menu 2 Footer

    SPA Flight- Component Modal-Component /FlightApp/flights(aux:info/modal)
  23. Aux-Routes Page ▪ 40 Logo + Menu Menu 2 Footer

    SPA Flight-Edit- Component Modal-Component /FlightApp/flights(aux:info/modal)/17
  24. Use Cases • Modale Dialoge • “Applets” und teilautonome Bereiche

    • Commander-Style Page ▪ 41
  25. Platzhalter definieren Page ▪ 42 <router-outlet></router-outlet> <hr> <router-outlet name="aux"></router-outlet> Standard-Name:

    primary
  26. Konfiguration Page ▪ 43 export const ROUTE_CONFIG: Routes = [

    { path: 'home', component: HomeComponent }, { path: 'info', component: InfoComponent, outlet: 'aux' }, { path: 'dashboard', component: DashboardComponent, outlet: 'aux' } ]
  27. Aux-Routes routen Page ▪ 44 <a [routerLink]="[{outlets: { aux: 'info'

    }}]"> Activate Info </a> <a [routerLink]="[{outlets: { aux: null }}]"> Deactivate Info </a>
  28. Mehrere Outlets gleichzeitig bestücken <a [routerLink]="[{outlets: { aux: 'basket', primary:

    'flight-booking/flight-search' }}]"> … </a> <a [routerLink]="[{outlets: { aux: 'basket', primary: ['flight-booking', 'flight-search'] }}]"> … </a> <a [routerLink]="[{outlets: { aux: 'basket', primary: ['flight-booking', 'flight-edit', 17] }}]"> … </a>
  29. Programmatisch routen Page ▪ 46 export class AppComponent { constructor(private

    router: Router) { } activateInfo() { this.router.navigate([{outlets: { aux: 'info' }}]); } deactivateInfo() { this.router.navigate([{outlets: { aux: null }}]); } }
  30. DEMO Page ▪ 47

  31. Guards Page ▪ 48

  32. Was sind Guards? • Services • Können Aktivierung und Deaktivierung

    von Routen verhindern Page ▪ 49
  33. Guards Rückgabewert: boolean | Observable<boolean> | Promise<boolean> CanActivate canActivate CanActivateChild

    canActivateChild CanLoad canLoad CanDeactivate<T> canDeactivate
  34. Guards in der Konfiguration Page ▪ 52 const APP_ROUTES: Routes

    = [ { path: '/flug-buchen', component: FlugBuchenComponent, canActivate: [AuthGuard], children: [ { path: 'flug-edit/:id', component: FlugEditComponent, canDeactivate: [FlugEditGuard] }, […] ] ]
  35. Provider für Guards Page ▪ 55 // app.module.ts @NgModule({ providers:

    [ FlugEditGuard, AuthGuard ], […] }) export class AppModule { }
  36. DEMO Page ▪ 56

  37. Resolver

  38. Was sind Resolver? • Services • Werden beim Routenwechsel aktiv

    • Verzögern Aktivierung der neuen Route • Laden benötigte Daten • Zwischenzeitlich kann z. B. Loading Indikator angezeigt werden
  39. Resolver @Injectable() export class FlightResolver implements Resolve<Flight> { constructor(private flightService:

    FlightService) { } resolve(route, state): Observable<Flight> | Promise<Flight> | Flight { return […] } }
  40. Resolver registrieren const FLIGHT_BOOKING_ROUTES: Routes = [ […] { path:

    'flight-edit/:id', component: FlightEditComponent, resolve: { flight: FlightResolver } } ];
  41. Daten entgegennehmen @Component({ … }) export class FlightEditComponent { flight:

    Flight; constructor(private route: ActivatedRoute) { } ngOnInit() { this.route.data.subscribe( data => { this.flight = data['flight']; } ); } }
  42. DEMO

  43. Lazy Loading Page ▪ 64

  44. Warum Lazy Loading? • Module erst bei Bedarf nachladen •

    Verbesserung der Start-Performance Page ▪ 65
  45. Root Module mit Lazy Loading Page ▪ 66 const APP_ROUTE_CONFIG:

    Routes = [ { path: '', redirectTo: 'home', pathMatch: 'full' }, { path: 'home', component: HomeComponent }, { path: 'flights', loadChildren: '[…]flight-booking.module#FlightBookingModule' } ];
  46. Root Module mit Lazy Loading Page ▪ 67 const APP_ROUTE_CONFIG:

    Routes = [ { path: '', redirectTo: 'home', pathMatch: 'full' }, { path: 'home', component: HomeComponent }, { path: 'flights', loadChildren: () => import('[…]flight-booking.module') .then(m => m.FlightBookingModule); } ];
  47. Routen für Feature Module Page ▪ 68 const FLUG_ROUTES =

    [ { path: '', component: FlugBuchenComponent, […] }, […] }
  48. Routen für Feature Module Page ▪ 69 const FLUG_ROUTES =

    [ { path: 'subroute', component: FlugBuchenComponent, […] }, […] }
  49. DEMO Page ▪ 71

  50. Preloading Page ▪ 72

  51. Idee • Eventuell später benötigte Module werden mit freien Ressourcen

    vorgeladen • Wird das Modul später tatsächlich benötigt, steht es augenblicklich zur Verfügung Page ▪ 73
  52. Preloading aktivieren Page ▪ 74 export const AppRoutesModule = RouterModule.forRoot(

    ROUTE_CONFIG, { preloadingStrategy: PreloadAllModules });
  53. Zusammenfassung Child Routes Aux Routes Guards Resolver Lazy Loading &

    Preloading
  54. Kontakt and Downloads [mail] manfred.steyer@SOFTWAREarchitekt.at [web] SOFTWAREarchitekt.at [twitter] ManfredSteyer d

    Slides & Examples Public and In-House http://www.softwarearchitekt.at/workshops