let's route this

 


    [
      {
        path: '',
        canActivate: [CanActivateMessagesAndContacts],
        resolve: {
          token: TokenNeededForBothMessagsAndContacts
        },
    
        children: [
          {
            path: 'messages',
            component: MesssagesCmp
          },
          {
            path: 'contacts',
            component: ContactsCmp
          }
        ]
      }
    ]

    const routes: Routes = [
      { path: '', component: HomeComponent, pathMatch: 'full' },
      { path: 'studio/:studioId', component: StudioComponent, children: [
        { path: 'artists', component: ArtistsListComponent, outlet: 'list' },
        { path: ':id', component: ArtistDescription, outlet: 'artist' }
      ] }
    ];
  
    <div class="columns">
        <router-outlet name="list"></router-outlet>
        <router-outlet name="artist"></router-outlet>
    </div>

    const routes: Routes = [
      { path: '', component: HomeComponent, pathMatch: 'full' },
      { path: 'studio/:studioId', component: StudioComponent, children: [
        { path: 'artists', component: ArtistsListComponent, outlet: 'list' },
        { path: ':id', component: ArtistDescription, outlet: 'artist' }
      ] }
    ];

   [routerLink]="['/studio/{{studio.id}}', {outlets: {'list': ['artists'], 'artist': ['']}}]">

    http://localhost:4200/studio/4/(artist:1//list:artists) 

    const routes: Routes = [
      { path: '', component: HomeComponent, pathMatch: 'full' },
      { path: 'studio/:studioId', component: StudioComponent, children: [
        { path: 'artists', component: ArtistsListComponent, outlet: 'list' },
        { path: ':id', component: ArtistDescription, outlet: 'artist' }
      ] }
    ];

Ordnung muss sein

- K. Sökölowski


    LanderModule,
    OfferModule,
    LoginModule,
    AffiliateNetworkModule,
    BulkActionsModule,
    PageNotFoundModule

<=  wildcard!

Matching strategy


    pathMatch: 'prefix' //default


    pathMatch: 'full'

Matching strategy


    pathMatch: 'prefix' //default


    pathMatch: 'full'

    { path: '', component: HomeComponent, pathMatch: 'full' }

    { path: '', component: HomeComponent }

navigate vs navigateByUrl


    /inbox/11/messages/22(popup:compose)
router.navigateByUrl('/inbox/33/messages/44')
router.navigate('/inbox/33/messages/44')
/inbox/33/messages/44(popup:compose)
/inbox/33/messages/44
    
    router.navigate('/inbox/33/messages/44')
    
    router.navigate(['/inbox/33/messages/44'])
    
    router.navigate(['/inbox', 33, 'messages', 44])

Suga suga how you get so fly

Guards

Tak, wiem, że w oryginale to
jest Walker Texas Ranger

  • CanActivate
  • CanDeactivate
  • CanActivateChild
  • CanLoad
  • Resolve

    { enableTracing: true }

Debugging

Let's talk

  • Resolvers vs. async loading inside component (instant click -> action feeling)
  • Outlets - they seem to be a bit messy, do we ever wanna use them?
  • ActivatedRouteSnapshot vs. Observables ("To avoid unnecessary DOM modifications, the router will reuse the components when the parameters of the corresponding routes change.")
  • ???

Let's route this

By Rafał Rumanek (truti)

Let's route this

  • 377