Nella mia pagina ho una navigazione secondaria che mostra alcune sottoview sotto una vista principale comune. Vorrei passare un oggetto alle visualizzazioni secondarie tramite <router-outlet>
in modo da poter recuperare i dati una volta nel componente principale e condividerli con i miei componenti secondari.Angular2 using @Inputs con <router-outlet> s
Nota: se includo la direttiva <one></one>
nel main.html, funziona ma questo non è il comportamento desiderato.
Vista principale:
<h1>Details</h1>
<a [router-link]="['./sub1']">One</a> |
<a [router-link]="['./sub2']">Two</a> |
<a [router-link]="['./sub3']">Three</a>
<hr/>
<router-outlet [data]="maindata"></router-outlet>
Sub View 1:
<h2>{{ data.name }}</h2>
...
Vista principale:
@Component({
selector: 'main-detail',
directives: [ROUTER_DIRECTIVES],
templateUrl: './main.html'
})
@RouteConfig([
{ path: '/', redirectTo: '/one' },
{ path: '/one', as: 'One', component: OneComponent },
{ path: '/two', as: 'Two', component: TwoComponent },
{ path: '/three', as: 'Three', component: ThreeComponent }
])
export class MainComponent {
maindata: Object = {name:'jim'};
}
Sub View 1:
@Component({
selector: 'one',
directives: [CORE_DIRECTIVES],
inputs: ['data'],
templateUrl: './one.html'
})
export class OneComponent {
@Input() data;
}
Controllare questo [problema] (https://github.com/angula r/angular/issues/4452) –