Angularjs 在angular2中动态加载仪表板内容

Angularjs 在angular2中动态加载仪表板内容,angularjs,angular,material-design,Angularjs,Angular,Material Design,我有一个angular2应用程序,具有以下材料设计布局 我已经将侧边栏、标题和仪表板分离为单独的组件。我想基于侧栏上的用户剪辑动态加载中间的仪表板。 如何才能做到这一点。非常感谢您的帮助 import {Component} from 'angular2/core'; import {Router, RouteConfig, ROUTER_DIRECTIVES,CanActivate} from 'angular2/router'; import {AuthHttp,AuthConfig, t

我有一个angular2应用程序,具有以下材料设计布局

我已经将侧边栏、标题和仪表板分离为单独的组件。我想基于侧栏上的用户剪辑动态加载中间的仪表板。 如何才能做到这一点。非常感谢您的帮助

import {Component} from 'angular2/core';
import {Router, RouteConfig, ROUTER_DIRECTIVES,CanActivate} from 'angular2/router';
import {AuthHttp,AuthConfig, tokenNotExpired, AUTH_PROVIDERS} from 'angular2-jwt';


import {HomeComponent} from '../home/HomeComponent'
import {AboutComponent} from '../about/AboutComponent'
import {HeaderComponent} from './HeaderComponent'
import {LoginComponent} from '../login/LoginComponent'
import {AuthService} from '../../services/AuthService'
import {SidebarComponent} from './SidebarComponent'
import {DashboardComponent} from './DashboardComponent'


@RouteConfig([
    {path: 'app/home', component: HomeComponent, as: 'Home'},
    {path: 'app/about', component: AboutComponent, as: 'About'},    
    {path: 'app/login', component: LoginComponent, as: 'Login'},
    {path: 'app/*', redirectTo: ['Login']}   // this redirect is not working for some reason
])
@Component({
    selector: 'my-app',
   template: `
    <body>
    <div class="demo-layout mdl-layout mdl-js-layout mdl-layout--fixed-drawer mdl-layout--fixed-header">
      <app-header class="demo-header mdl-layout__header mdl-color--grey-100 mdl-color-text--grey-600"></app-header>
      <app-sidebar class="demo-drawer mdl-layout__drawer mdl-color--blue-grey-900 mdl-color-text--blue-grey-50">
      </app-sidebar>
      <main class="mdl-layout__content mdl-color--grey-100">
        <dashboard></dashboard>
      </main>

    <script src="https://code.getmdl.io/1.1.3/material.min.js"></script>
  </body>
  <router-outlet></router-outlet>
    `, 
    directives: [ROUTER_DIRECTIVES,SidebarComponent,HeaderComponent,DashboardComponent],
    providers: [AUTH_PROVIDERS,AuthService]
})

export class AppComponent { 

  constructor() {}

}    
从'angular2/core'导入{Component};
从'angular2/Router'导入{Router,RouteConfig,Router_指令,CanActivate};
从“angular2 jwt”导入{AuthHttp、AuthConfig、tokenNotExpired、AUTH_PROVIDERS};
从“../home/HomeComponent”导入{HomeComponent}
从“../about/AboutComponent”导入{AboutComponent}
从“/HeaderComponent”导入{HeaderComponent}
从“../login/LoginComponent”导入{LoginComponent}
从“../../services/AuthService”导入{AuthService}
从“./SidebarComponent”导入{SidebarComponent}
从“./DashboardComponent”导入{DashboardComponent}
@线路图([
{path:'app/home',component:HomeComponent,as:'home'},
{path:'app/about',component:AboutComponent,as:'about'},
{path:'app/login',component:LoginComponent,as:'login'},
{path:'app/*',重定向到:['Login']}//由于某些原因,此重定向无法工作
])
@组成部分({
选择器:“我的应用程序”,
模板:`
`, 
指令:[路由器_指令、SidebarComponent、HeaderComponent、DashboardComponent],
提供者:[身份验证提供者,身份验证服务]
})
导出类AppComponent{
构造函数(){}
}    

RouterOutlet是您要路由到的组件内容的占位符。应将其放置在预期渲染路由内容的位置。在您的情况下,只需将
dasboard
标记替换为放置在模板底部的
router outlet
标记,如下所示:

@Component({
    selector: 'my-app',
   template: `
    <body>
    <div class="demo-layout mdl-layout mdl-js-layout mdl-layout--fixed-drawer mdl-layout--fixed-header">
      <app-header class="demo-header mdl-layout__header mdl-color--grey-100 mdl-color-text--grey-600"></app-header>
      <app-sidebar class="demo-drawer mdl-layout__drawer mdl-color--blue-grey-900 mdl-color-text--blue-grey-50">
      </app-sidebar>
      <main class="mdl-layout__content mdl-color--grey-100">
        <router-outlet></router-outlet>
      </main>

    <script src="https://code.getmdl.io/1.1.3/material.min.js"></script>
  </body>
    `, 
    directives: [ROUTER_DIRECTIVES,SidebarComponent,HeaderComponent],
    providers: [AUTH_PROVIDERS,AuthService]
})
@组件({
选择器:“我的应用程序”,
模板:`
`, 
指令:[路由器_指令、边栏组件、标题组件],
提供者:[身份验证提供者,身份验证服务]
})

为什么将
放在
主体
元素之外?此标记用于设置渲染路由输出的位置(Home、About、Login…),只要它位于模板``内,就不会有任何区别。。据我所知。不,
是一个占位符,可以替换为您路由到的组件的实际内容。我想你想要的是用
路由器插座
替换你的
仪表板
标签。。但仪表板模板显示在页面的最底部,而不是预期的右侧面板中。有什么想法吗?对不起,我的错。。我没有从底部移除另一个路由器插座,这就是原因。它正在工作。如果你能回答这个问题,我将把它标记为已接受。谢谢你的帮助。