【问题标题】:Trouble implementing lazy loaded feature module Angular 8难以实现延迟加载的功能模块Angular 8
【发布时间】:2019-11-12 17:52:40
【问题描述】:

所以基本上我正在尝试在我一直关注the official angular docs 的应用程序中创建一个延迟加载的功能模块 - 但由于某种原因它无法正常工作。

我的功能模块DashboardModule如下图所示

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

// MODULES
import { DashboardRoutingModule } from './dashboard-routing.module';

// COMPONENTS
import { DashboardComponent } from './dashboard/dashboard.component';
import { DashboardAlertComponent } from './dashboard-alert/dashboard-alert.component';
import { DashboardSummaryComponent } from './dashboard-summary/dashboard-summary.component';
import { DashboardTasksComponent } from './dashboard-tasks/dashboard-tasks.component';
import { HoldingPageComponent } from './holding-page/holding-page.component';

@NgModule({
    imports: [CommonModule, DashboardRoutingModule],
    declarations: [
        DashboardComponent,
        DashboardAlertComponent,
        DashboardSummaryComponent,
        DashboardTasksComponent,
        HoldingPageComponent,
    ]
})
export class DashboardModule {}

然后在我的 DashboardRoutingModule

import { NgModule } from '@angular/core';
import { RouterModule } from '@angular/router';

import { ActivityComponent } from '../activity-components/activity/activity.component';
import { IsLockedRouteGuard } from '@app/shared/common/auth/is-locked-route-guard';
import { DashboardSummaryComponent } from './dashboard-summary/dashboard-summary.component';
import { SyncComponent } from '@app/popup-components/sync/sync.component';
import { DashboardAlertComponent } from './dashboard-alert/dashboard-alert.component';
import { ChartContainerComponent } from '../chart-components/chart-container/chart-container.component';
import { DashboardTasksComponent } from './dashboard-tasks/dashboard-tasks.component';


@NgModule({
    imports: [
        RouterModule.forChild([
            { path: 'activity', component: ActivityComponent, canActivate: [IsLockedRouteGuard] },
            { path: 'snapshot', component: DashboardSummaryComponent },
            { path: 'sync', component: SyncComponent },
            {
                path: 'alerts',
                component: DashboardAlertComponent,
                canActivate: [IsLockedRouteGuard]
            },
            { path: 'charts', component: ChartContainerComponent, canActivate: [IsLockedRouteGuard] },
            { path: 'tasks/:sort', component: DashboardTasksComponent, canActivate: [IsLockedRouteGuard] },
        ])
    ],
    exports: [RouterModule]
})
export class DashboardRoutingModule {}

所以根据角度文档,这已正确设置..

现在在我的 AppRoutingModule

import { NgModule } from '@angular/core';
import { RouterModule } from '@angular/router';
import { AppComponent } from './app.component';
import { AppRouteGuard } from './shared/common/auth/auth-route-guard';

@NgModule({
    imports: [
        RouterModule.forChild([
            {
                path: 'app',
                component: AppComponent,
                children: [
                    {
                        path: '',
                        children: [{ path: '', redirectTo: '/dashboard/alerts', pathMatch: 'full' }]
                    },
                    {
                        path: 'main',
                        canActivate: [AppRouteGuard],
                        loadChildren: () => import('./main/main.module').then(m => m.MainModule),
                        data: { preload: true }
                    },
                    {
                        path: 'dashboard',
                        loadChildren: () => import('./main/dashboard/dashboard.module').then(m => m.DashboardModule)
                    },
                ]
            }
        ])
    ],
    exports: [RouterModule]
})
export class AppRoutingModule {}

但是当我尝试转到 /dashboard 时发生了什么。我收到此错误

Component HoldingPageComponent is not part of any NgModule or the module has not been imported into your module.

但我显然将其导入到 DashboardModule 中,如上所示。我做错了什么??

谢谢

【问题讨论】:

  • 您需要确保组件在使用前已加载。对我来说,您似乎在其父模块之外的某个地方使用了HoldingPageComponent,或者导入不正确。请交叉检查。
  • @Manish 是的,我正在将它导入另一个模块中,但我忘了删除它!谢谢这工作!

标签: javascript angular typescript


【解决方案1】:

我没看到

RouterModule.forRoot

我认为你应该在 AppRoutingModule 中使用它而不是

RouterModule.forChild

【讨论】:

  • 我的 AppRoutingModule 不是我的根路由模块,因此是 forChild
  • 这里少了一些东西
  • 只在根应用模块 AppModule 中调用 forRoot。在任何其他模块中调用它,尤其是在延迟加载的模块中,这与意图相反,可能会产生运行时错误。
猜你喜欢
  • 2018-05-22
  • 1970-01-01
  • 1970-01-01
  • 2017-02-22
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多