Подтвердить что ты не робот

Несколько именованных маршрутизаторов angular 2

Я хочу отображать разные представления дочерними маршрутами. Например, я хочу, чтобы мой шаблон содержал несколько маршрутизаторов-маршрутизаторов

Version: @angular/router": "3.0.0-alpha.7"

<router-outlet></router-outlet>
<router-outlet name="route1"></router-outlet>
<router-outlet name="route2"></router-outlet>

В моем маршрутизаторе я хочу указать имя маршрутизатора.

Как я увидел в вопросе, решение для этого - указать AuxRoute, но AuxRoute не существует в этой версии.

{path: '/',        component: HomeComponent, as: 'Home'},
new AuxRoute({path: '/route1', component: Route1Component, as: 'Route1'}),
new AuxRoute({path: '/route2', component: Route2Component, as: 'Route2'})

Пока на angular 2 официальном сайте я обнаружил, что возможно иметь несколько маршрутизаторов, но я не могу найти какой-либо ресурс.

https://angular.io/docs/ts/latest/guide/router.html

A template may hold exactly one unnamed <router-outlet>. The router supports multiple named outlets, a feature we'll cover in future.

4b9b3361

Ответ 1

Текущая версия с несколькими именами router-outlet (для angular2 RC.6 ^) выглядит следующим образом:

Конфигурация маршрутизатора

const appRoutes: Routes = [{   
    path: 'home',
      component: HomeComponent,
      children: [
        { path: '', component: LayoutComponent },
        { path: 'page1', component: Page1Component, outlet: 'route1' },
        { path: 'page2', component: Page2Component, outlet: 'route2' },
        { path: 'page3', component: Page3Component, outlet: 'route3' }
      ]
    }, {
      path: 'articles',
      component: ArticlesComponent,
      children: [
        { path: '', component: LayoutComponent },
        { path: 'article1', component: Article1Component, outlet: 'route1' },
        { path: 'article2', component: Article2Component, outlet: 'route2' }
      ]
    },  { 
      path: '', 
      redirectTo: '/home',
      pathMatch: 'full'
   }
];

Шаблон внутри Главная:

<router-outlet></router-outlet>
<router-outlet name="route1"></router-outlet>
<router-outlet name="route2"></router-outlet>
<router-outlet name="route3"></router-outlet>

И пример навигации из корневого компонента:

constructor(router: Router) {
  router.navigateByUrl('/home/(route1:page1//route2:page2//route3:page3)');
} 

Альтернативный способ:

<a [routerLink]="['/home', { outlets: {'route1':['page1'],'route2': ['page2'] }}]"></a>

Здесь live Пример плунжера

См. также