我有一个完整的角度应用程序,使用急切加载。我想将它转换为延迟加载,但因为我对所有路线都有防范,并且它们都是到一条保护的主路线的子路线,我不知道是否可以这样做并仍然使其功能化喜欢急切的装载。
这是app-routing.module中的路由数组:
// Routing array - set routes to each html page
const appRoutes: Routes = [
{ path: 'login/:id', canActivate: [AuthGuard], children: [] },
{ path: '', canActivateChild: [AuthGuard], children: [
{ path: '', redirectTo: '/courses', pathMatch: 'full' },
{ path: 'courses', component: CourseListComponent, pathMatch: 'full'},
{ path: 'courses/:courseId', component: CourseDetailComponent, pathMatch: 'full' },
{ path: 'courses/:courseId/unit/:unitId', component: CoursePlayComponent,
children: [
{ path: '', component: CourseListComponent },
{ path: 'lesson/:lessonId', component: CourseLessonComponent, data:{ type: 'lesson'} },
{ path: 'quiz/:quizId', component: CourseQuizComponent, data: {type: 'quiz'} }
]}
]},
{ path: 'welcome', component: LandingPageComponent, pathMatch: 'full' },
{ path: '**', component: PageNotFoundComponent, pathMatch: 'full' }];
我想知道的是,是否可以通过延迟加载实现这一点,如果是这样,我想知道主要想法或我需要知道的事情才能做到这一点。
在我做的所有教程中,我从未遇到过这种事情。非常感谢你
来自我的某个应用的示例代码:
const routes: Routes = [
{
path: 'login',
component: SignupLoginMainContainerComponent,
canActivate: [AuthGuard],
},
{
path: 'error',
component: ErrorComponent
},
{
// lazy loading payment module
path: 'payment',
loadChildren: './modules/payment/payment.module#PaymentModule'
},
{
// lazy loading private module
path: '',
loadChildren: './modules/private/private.module#PrivateModule',
canLoad: [AuthGuard]
},
{path: '**', redirectTo: '/login'},
];
AuthGuard实施:
export class AuthGuard implements CanActivate, CanLoad {
canActivate(
next: ActivatedRouteSnapshot,
state: RouterStateSnapshot
): Observable<boolean> | Promise<boolean> | boolean {
return (some condition) ? true : false
}
canLoad(route: Route): boolean {
return (some condition based on route etc) ? true : false
}
}
私有模块拥有路由文件,进一步加载更多子模块:
const routes: Routes = [
{
path: '',
component: PrivateComponent,
canActivateChild: [AuthGuard],
children: [
{
path: 'childOne',
loadChildren: '../child-one/child-one.module#ChildOneModule',
canLoad: [AuthGuard],
},
{
path: 'childTwo',
loadChildren: '../child-two/child-two.module#ChildTwoModule',
canLoad: [AuthGuard],
},
{
path: '',
redirectTo: '/dashboard',
pathMatch: 'full',
},
],
},
];
另一个例子可以在:https://github.com/ashishgkwd/bot/tree/24-lazy-loading-modules找到。 AdminModule
在这个懒惰的装载。
For lazy loading you should use:
import {ComponentName} from 'component path';
const routes: Routes = [
//for module
{
path: 'path_Name',
loadChildren: './modules/abc/abc.module#AbcModule'
},
//for component
{
path: 'browser',
component: ComponentName
},
];
谢谢大家的答案。我成功地将我的路由转换为延迟加载。这是代码:
APP-routing.module
import { NgModule } from '@angular/core';
import { Routes, RouterModule, Router } from '@angular/router';
import { AuthGuard } from './auth.guard';
import { AppComponent } from './app.component';
import { PageNotFoundComponent } from './page-not-found/page-not-found.component';
import { LandingPageComponent } from './landing-page/landing-page.component';
import { HeaderComponent } from './header/header.component';
import { CourseModule } from './courses/course.module';
const routes:Routes = [
{ path: 'welcome', component: LandingPageComponent, pathMatch: 'full' },
{ path: 'login/:id', canActivate: [AuthGuard], children: [] },
{ path: '', canActivateChild: [AuthGuard], children: [
{ path: '', redirectTo: 'courses', pathMatch: 'full' },
{ path: 'courses', loadChildren: () => CourseModule }
]},
{ path: '**', component: PageNotFoundComponent, pathMatch: 'full' }
]
@NgModule({
imports: [RouterModule.forRoot(routes, { onSameUrlNavigation: 'reload', initialNavigation: 'enabled',
paramsInheritanceStrategy: 'always' })],
providers: [AuthGuard],
exports: [RouterModule]
})
export class AppRoutingModule { }
当然,routing.module
import { NgModule } from '@angular/core';
import { RouterModule, Routes } from "@angular/router";
import { AuthGuard } from '../auth.guard';
import { CourseListComponent } from './course-list/course-list.component';
import { CourseDetailComponent } from './course-detail/course-detail.component';
import { CoursePlayComponent } from './course-play/course-play.component';
import { CourseQuizComponent } from './course-play/course-quiz/course-quiz.component';
import { CourseLessonComponent } from './course-play/course-lesson/course-lesson.component';
const routes:Routes = [
{ path: '', component: CourseListComponent, canActivate: [AuthGuard] },
{ path: ':courseId', component: CourseDetailComponent, canActivate: [AuthGuard] },
{ path: ':courseId/unit/:unitId', component: CoursePlayComponent, canActivate: [AuthGuard], canActivateChild: [AuthGuard], children: [
{ path: 'lesson/:lessonId', component: CourseLessonComponent, data:{ type: 'lesson'} },
{ path: 'quiz/:quizId', component: CourseQuizComponent, data: {type: 'quiz'}}
]}
]
@NgModule({
imports: [RouterModule.forChild(routes)],
exports: [RouterModule]
})
export class CourseRoutingModule { }
auth.guard
import { Injectable } from '@angular/core';
import { Observable, throwError } from 'rxjs';
import { Router, CanActivate, CanActivateChild, CanLoad, ActivatedRouteSnapshot, RouterStateSnapshot, NavigationExtras, Route } from '@angular/router';
import { AuthUserService } from './users/auth-user.service';
import { LocalStorage } from '@ngx-pwa/local-storage';
@Injectable()
export class AuthGuard implements CanActivate , CanActivateChild {
constructor(private authUserService: AuthUserService, private router: Router) { }
canActivate(route: ActivatedRouteSnapshot, state:
RouterStateSnapshot): boolean |
Observable<boolean> | Promise<boolean> {
let id, course_id;
// save the id from route snapshot
if (route.params) {
id = +route.params.id;
course_id = +route.params.courseId;
}
// if you try to logging with id
if (id) {
this.router.navigate(["/courses"]);
return this.authUserService.login(id);
}
// if you're already logged in and navigate between pages
if (this.authUserService.isLoggedIn()){
if (course_id){
// check if someone try to access a locked course
if (this.authUserService.isCourseNotPartOfTheSubscription(course_id)){
this.router.navigate(["/welcome"]);
return false;
}
else
return true;
}
else
return true;
}
// if you are not logged and didn't try to log - redirect to landing page
else {
this.router.navigate(["/welcome"]);
return false;
}
}
canActivateChild(route: ActivatedRouteSnapshot,state: RouterStateSnapshot): boolean |
Observable<boolean> | Promise<boolean> {
return this.canActivate(route, state);
}
canLoad(route: ActivatedRouteSnapshot,state: RouterStateSnapshot): boolean |
Observable<boolean> | Promise<boolean> {
return this.canActivate(route, state);
}
}