未捕获(承诺):错误:无法匹配任何路由(Angular8)

问题描述 投票:0回答:1

我制作了我的angular-app。所有的好作品。但是对于部署到服务器我得到错误:

未捕获(承诺):错误:无法匹配任何路线。网址段:'myUrl / app.aspx'

构建产品后,我的应用程序也不起作用(我设置了基本href并加载了所有文件,但收到警告Unhandled Navigation Error

我为我的应用设置了路由难度。我使用子模块进行路由。而且我认为问题与APP_BASE_HREF或我的应用程序/子模块的路由错误有关。

我的示例:

app.module.ts

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { HttpClientModule } from "@angular/common/http";
import { AppComponent } from './app.component';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import { NbThemeModule, NbLayoutModule, NbSidebarModule, NbButtonModule, NbTabsetModule, NbCardModule } from '@nebular/theme';
import { NbEvaIconsModule } from '@nebular/eva-icons';
import { AppRoutingModule } from './app-routing.module';
import { RouterModule } from '@angular/router';
import { MainModule } from './components/main/main.module';
import { AddModule } from './components/add/add.module';
import { APP_BASE_HREF } from '@angular/common';

@NgModule({
  declarations: [
    AppComponent,
  ],
  imports: [
    BrowserModule,
    BrowserAnimationsModule,
    NbThemeModule.forRoot({ name: 'default' }),
    NbLayoutModule,
    NbEvaIconsModule,
    NbSidebarModule.forRoot(),
    NbButtonModule,
    NbTabsetModule,
    NbCardModule,
    AppRoutingModule,
    MainModule,
    AddModule,
    HttpClientModule,
  ],
  providers: [{ provide: APP_BASE_HREF, useValue: '/' }],
  bootstrap: [AppComponent]
})
export class AppModule { }

我没有提供者:[{提供:APP_BASE_HREF,useValue:'/'}]和所有不错的作品。但是对于部署,我得到了错误消息:

[请提供APP_BASE_HREF令牌的值或添加一个底数元素。

我添加了APP_BASE_HREF,错误消失了。

app-routing.module.ts

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

const routes: Routes = [
  {
    path: '',
    loadChildren: './components/main/main.module#MainModule'
  },
  {
    path: 'event',
    loadChildren: './components/event/event.module#EventModule'
  },
  {
    path: 'add',
    loadChildren: './components/add/add.module#AddModule'
  },
  {
    path: 'archive',
    loadChildren: './components/archive/archive.module#ArchiveModule'
  }
];

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

main-routing.module.ts

import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { ViewEventsComponent } from './view-events/view-events.component';

const routes: Routes = [
    {
        path: '',
        component: ViewEventsComponent,
    },
];

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

event-routing.module.ts

import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { EventPageComponent } from './event-page/event-page.component';

const routes: Routes = [
    {
        path: ':id',
        component: EventPageComponent,
    },
];

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

我注意到:

构建应用程序后-生成的模块文件:存档和事件,但未生成主模块的文件。

javascript angular routing angular8 angular-routing
1个回答
0
投票

我通过修复[[app-routing.module.ts中的问题解决了这个问题。添加的{useHash:true}:

@NgModule({ imports: [RouterModule.forRoot(routes, { useHash: true })], exports: [RouterModule], })
© www.soinside.com 2019 - 2024. All rights reserved.