在angular2中嵌套路由中的问题

时间:2016-06-15 21:07:26

标签: angular angular2-routing

我有一个场景,我需要加载一个使用angular2路由构建的菜单。在特定组件内部,我需要加载另一个菜单/选项卡,这只是另一个angular2路由组件。请查看我的要求here

的快照

请找到主菜单的代码

import {Component, bind} from 'angular2/core';
import {ROUTER_PROVIDERS, RouteConfig, ROUTER_DIRECTIVES, APP_BASE_HREF, LocationStrategy, RouteParams, ROUTER_BINDINGS} from 'angular2/router';
import {bootstrap}        from 'angular2/platform/browser';

import {ComponentOne} from '../Dashboard/Dashboard1';
import {ComponentTwo} from '../Dashboard/Dashboard2';
import {ReportOne} from '../Reports/Report1';
import {menutopbar} from './menutopbar';
import {leftmenu} from './leftmenu';
import {Clicksenselink} from './clicksenselink';
import {ManageRedisCache} from '../Admin/ManageRedisCache';

@Component({
    selector: 'comp-menu',
    templateUrl: './Menu.html',
    directives: [menutopbar, leftmenu, ManageRedisCache, ROUTER_DIRECTIVES]
   // providers: [ROUTER_PROVIDERS]
})

@RouteConfig([
        { path: '/Dashboard1', name: 'ComponentOne', component: ComponentOne },
        { path: '/Dashboard2', name: 'ComponentTwo', component: ComponentTwo },
        { path: '/Report1', name: 'ReportOne', component: ReportOne },
        { path: '/Clicksenselink', name: 'Clicksenselink', component: Clicksenselink },
        { path: '/ManageRedisCache/...', name: 'ManageRedisCache', component: ManageRedisCache}
])

export class componentmenu {
    constructor() {
        console.log("componentmenu component being called");
    }
}

请找到内部加载另一个路由组件的子组件的代码

import {Component, bind} from 'angular2/core';
import {RouteConfig, ROUTER_DIRECTIVES, APP_BASE_HREF, LocationStrategy, RouteParams, ROUTER_BINDINGS, RouterOutlet} from 'angular2/router';
import {bootstrap}        from 'angular2/platform/browser';
import {AfterViewInit} from 'angular2/core';   


import {Extractor} from './Extractor';
import {ExtractorQueue} from './ExtractorQueue';
import {Schedule} from './Schedule';
import {DefaultComponent} from './DefaultComponent';


@Component({
    template: `
<div class="container">
    <h2>Redis Administration</h2>
    <ul class="nav nav-tabs">
        <li class="active"><a data-toggle="tab" [routerLink]="['Extractor']">Extractor</a></li>
        <li><a data-toggle="tab" [routerLink]="[ 'ExtractorQueue']">ExtractorQueue</a></li>
        <li><a data-toggle="tab"  [routerLink]="['Schedule']">Schedule</a></li>
    </ul>
    <div class="tab-content">
        <router-outlet></router-outlet>
      </div>
</div>
`,
    directives: [Extractor, ExtractorQueue, Schedule, RouterOutlet]
})

    @RouteConfig
        ([
    { path: '/', name: 'Default', component: DefaultComponent},
    { path: '/Extractor', name: 'Extractor', component: Extractor, useAsDefault: true},
    { path: '/ExtractorQueue', name: 'ExtractorQueue', component: ExtractorQueue },
    { path: '/Schedule', name: 'Schedule', component: Schedule }
])

export class ManageRedisCache
{ }

当我运行我的应用程序时,我在chrome控制台

中收到以下异常
Can't bind to 'routerLink' since it isn't a known native property ("s Administration</h2>
    <ul class="nav nav-tabs">
        <li class="active"><a data-toggle="tab" [ERROR ->][routerLink]="['Extractor']">Extractor</a></li>
        <li><a data-toggle="tab" [routerLink]="[ 'Ext"): ManageRedisCache@4:48
Can't bind to 'routerLink' since it isn't a known native property (" data-toggle="tab" [routerLink]="['Extractor']">Extractor</a></li>
        <li><a data-toggle="tab" [ERROR ->][routerLink]="[ 'ExtractorQueue']">ExtractorQueue</a></li>
        <li><a data-toggle="tab"  [routerL"): ManageRedisCache@5:33
Can't bind to 'routerLink' since it isn't a known native property ("="tab" [routerLink]="[ 'ExtractorQueue']">ExtractorQueue</a></li>
        <li><a data-toggle="tab"  [ERROR ->][routerLink]="['Schedule']">Schedule</a></li>
    </ul>
    <div class="tab-content">
"): ManageRedisCache@6:34 ; Zone: angular ; Task: Promise.then ; Value: BaseExceptionconsoleError @ code.angularjs.org/2.0.0-beta.16/angular2-polyfills.js:487
code.angularjs.org/2.0.0-beta.16/angular2-polyfills.js:489 Error: Uncaught (in promise): Template parse errors:(…)consoleError @ code.angularjs.org/2.0.0-beta.16/angular2-polyfills.js:489

如何解决此问题的任何想法?

1 个答案:

答案 0 :(得分:0)

你应该更新到ng2-rc ......无论如何,请阅读更多https://angular.io/docs/ts/latest/guide/router-deprecated.html

要嵌套路由,您需要添加3个点

{ path: '/ManageRedisCache/...'

并在ManageRedisCache中有一个默认路由

 { path: '/', name: 'default', component: default},

并在ManageRedisCache中添加routeroutlet指令