Загрузка маршрутов через JSON в Angular2
Я пытаюсь загрузить маршруты из файла JSON, так как не хочу жестко их кодировать и лениво загружать маршруты. Что-то вроде этого:
import { RouterModule } from '@angular/router';
const routes = [
{ path: '', loadChildren: 'app/home/home.module' },
{ path: ':item/shoes', loadChildren: 'app/shoes/shoes.module' },
{ path: ':item/watch', loadChildren: 'app/watch/watch.module' }
];
export default RouterModule.forRoot(routes);
{ path: '', loadChildren: 'app/home/home.module' },
{ path: ':item/shoes', loadChildren: 'app/shoes/shoes.module' },
{ path: ':item/watch', loadChildren: 'app/watch/watch.module' }
Я читаю файл JSON, используя сервис, который внедряется в компонент. Как ввести сервис в маршрутизатор, чтобы получить значения? Или есть какой-то другой лучший способ, с помощью которого я могу загрузить маршруты из JSON?
1 ответ
Это работает для меня:
приложение-routing.module.ts
import { NgModule } from '@angular/core';
import { RouterModule, Routes, Router } from '@angular/router';
import * as AppRoutingJson from "./app-routing.json";
import { HomeComponent } from "./main/content/pages/joomla/home/home.component";
import { PageNotFoundComponent } from "./main/content/pages/joomla/page-not-found/page-not-found.component";
const routes: Routes = [
{
path: '',
component : HomeComponent
}
];
@NgModule({
imports: [ RouterModule.forRoot(routes) ],
exports: [ RouterModule ],
entryComponents: [
PageNotFoundComponent
]
})
export class AppRoutingModule {
constructor( private router: Router ){
this.prepareRoutes( AppRoutingJson );
}
prepareRoutes( routesJson: any ) {
let routesArr = <Routes>[];
routesArr = routesJson;
routesArr.forEach( route => {
routes.push( route );
});
routes.push(
{
"path" : 'page-not-found',
"component" : PageNotFoundComponent,
},
{
"path" : '**',
"redirectTo" : 'page-not-found'
}
);
this.router.resetConfig( routes );
}
}