无法识别角形路由器出口

时间:2019-06-08 01:24:18

标签: angular typescript angular2-routing

为了增强我的技能,我尝试了所有有棱角的想法

在这种情况下,我正在尝试路由由两个功能模块和一个共享模块组成的功能模块。

我的生根是使用cli命令ng g m router --routing生成的,并按如下所示进行了手工更新

import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { InterpolationComponent } from '../exemple100/interpolation/interpolation.component'
import { PageNotFoundComponent } from '../page-not-found/page-not-found.component';
import { AppComponent } from '../app.component';
import { Ex200Component } from '../ex200/ex200.component';
import { Ex300Component } from '../ex300/ex300.component';
import { Ex400Component } from '../ex400/ex400.component';
import { Ex500Component } from '../ex500/ex500.component';
import { SalesComponent } from '../ex500/sales/sales.component';
import { SupportComponent } from '../ex500/support/support.component';

const routes: Routes = [
  {path: 'ex100', component: InterpolationComponent },
  {path: 'ex200', component: Ex200Component },
  {path: 'ex300', component: Ex300Component },
  {path: 'ex400', component: Ex400Component },
  {path: 'ex500', component: Ex500Component },
  {path: 'ex500/sales', component: SalesComponent },
  {path: 'ex500/support', component: SupportComponent },
  {path: '**', component: PageNotFoundComponent },
  {path: '', component: AppComponent }
];

@NgModule({
  imports: [RouterModule.forRoot(routes)],
  exports: [RouterModule]
})
export class RouterRoutingModule { }

import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';

import { RouterRoutingModule } from './router-routing.module';

@NgModule({
  declarations: [],
  imports: [
    CommonModule,
    RouterRoutingModule
  ]
})
export class RouterModule { }

然后我手动更新引导应用程序模块

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';

import { AppComponent } from './app.component';
import { InterpolationComponent } from './exemple100/interpolation/interpolation.component';
import { Ex200Component } from './ex200/ex200.component';
import { Ex300Component } from './ex300/ex300.component';
import { FormsModule } from '@angular/forms';
import { Ex400Component } from './ex400/ex400.component';
import { PageNotFoundComponent } from './page-not-found/page-not-found.component';
import { RouterModule } from './router/router.module';
import { Ex500Module } from './ex500/ex500.module';

@NgModule({
  declarations: [
    AppComponent,
    InterpolationComponent,
    Ex200Component,
    Ex300Component,
    Ex400Component,
    PageNotFoundComponent
  ],
  imports: [BrowserModule, FormsModule, RouterModule, Ex500Module],
  providers: [],
  bootstrap: [AppComponent]
})
export class AppModule {}

Ex500Module是我组成的功能模块(销售和支持:都在使用共享模块)

我的主要组件无法识别我的路由器出口,为什么?

exception in router-outlet

对于我对角度路由和模块处理的基本了解:

  

导入模块就是导入它导出的组件:在我的情况下,RouterModule(@ angular / router)是在RouterRoutingModule中导出的,而RouterRoutingModule是通过我的RouterModule(./ router / router.module)导入到AppModule中的。导出的组件应导入

1 个答案:

答案 0 :(得分:1)

我不确定为什么会有两个名为RouterRouterRouting的模块,但是如果这样做,则需要在中间模块中重新导出路由器

@NgModule({
  declarations: [],
  imports: [
    CommonModule,
    RouterRoutingModule
  ],
export: [ RouterRoutingModule ]
})
export class RouterModule { }