首页 > 其他 > 详细

[Angular 2] Child Router

时间:2016-04-19 06:28:00      阅读:279      评论:0      收藏:0      [点我收藏+]

Benefit to use child router is Angualr 2 then can lazy load the component on demand. 

 

Define a child router by adding three dots `/characters/...`:

@RouteConfig([
  { path: /characters/..., name: Characters, component: CharactersComponent, useAsDefault: true },
  { path: /vehicles/..., name: Vehicles, component: VehiclesComponent }
])

So both `characters` and `vehicles` component container child router.

 

Then in each component, we define its child rotuer

import { Component } from angular2/core;
import { RouteConfig, ROUTER_DIRECTIVES } from angular2/router;

import { CharacterComponent } from ./character.component;
import { CharacterListComponent } from ./character-list.component;
import { CharacterService } from ./character.service;

@Component({
  selector: story-characters-root,
  template: `
    <router-outlet></router-outlet>
  `,
  directives: [ROUTER_DIRECTIVES]
})
@RouteConfig([
  { path: /, name: Characters, component: CharacterListComponent, useAsDefault: true },
    { path: /:id, name: Character, component: CharacterComponent }
])
export class CharactersComponent { }

 

import { Component, OnInit } from angular2/core;
import { RouteConfig, ROUTER_DIRECTIVES } from angular2/router;

import { VehicleListComponent } from ./vehicle-list.component;
import { VehicleComponent } from ./vehicle.component;
import { VehicleService } from ./vehicle.service;

@Component({
  selector: story-vehicles-root,
  template: `
    <router-outlet></router-outlet>
  `,
  directives: [ROUTER_DIRECTIVES],
  providers: [VehicleService]
})
@RouteConfig([
  { path: /, name: Vehicles, component: VehicleListComponent, useAsDefault: true },
    { path: /:id, name: Vehicle, component: VehicleComponent }
])
export class VehiclesComponent { }

 

----------------

The list component, set routerLink:

<ul class="characters">
    <li *ngFor="#character of characters | async">
      <a href="" [routerLink]="[‘Character‘, {id: character.id}]">
       {{character.id}}. {{character.name}}
      </a>
    </li>
  </ul>

 

[Angular 2] Child Router

原文:http://www.cnblogs.com/Answer1215/p/5406643.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!