Dan*_*cal 5 angular-routing angular-module angular angular-router
我想将这个自定义路由重用策略用于一个模块:
export class CustomRouteReuseStrategy extends RouteReuseStrategy {
public shouldDetach(route: ActivatedRouteSnapshot): boolean { return false; }
public store(route: ActivatedRouteSnapshot, detachedTree: DetachedRouteHandle): void {}
public shouldAttach(route: ActivatedRouteSnapshot): boolean { return false; }
public retrieve(route: ActivatedRouteSnapshot): DetachedRouteHandle { return null; }
public shouldReuseRoute(future: ActivatedRouteSnapshot, curr: ActivatedRouteSnapshot): boolean {
return true;
}
}
Run Code Online (Sandbox Code Playgroud)
所以我在我的一个名为的模块中传入@NgModule()ChildModule:
providers: [
{
provide: RouteReuseStrategy,
useClass: CustomRouteReuseStrategy
}
]
Run Code Online (Sandbox Code Playgroud)
不幸的是,当我在那里传递它时,它会被忽略.虽然添加到我的根目录时工作正常AppModule...我不确定它是否重要,但是ChildModule懒得加载.怎么解决?
Dan*_*cal 15
我终于通过传递一点修改CustomRouteStrategy来实现它AppModule:
export class CustomRouteReuseStrategy extends RouteReuseStrategy {
public shouldDetach(route: ActivatedRouteSnapshot): boolean { return false; }
public store(route: ActivatedRouteSnapshot, detachedTree: DetachedRouteHandle): void {}
public shouldAttach(route: ActivatedRouteSnapshot): boolean { return false; }
public retrieve(route: ActivatedRouteSnapshot): DetachedRouteHandle { return null; }
public shouldReuseRoute(future: ActivatedRouteSnapshot, curr: ActivatedRouteSnapshot): boolean {
return (future.routeConfig === curr.routeConfig) || future.data.reuse;
}
}
Run Code Online (Sandbox Code Playgroud)
并添加data: { reuse: true }到延迟加载的路由ChildModule:
{
path: 'some-path',
data: { reuse: true },
loadChildren: './child.module#ChildModule',
},
Run Code Online (Sandbox Code Playgroud)
小智 5
定制路线策略
import {RouteReuseStrategy,DetachedRouteHandle,ActivatedRouteSnapshot} from '@angular/router';
export class CustomReuseStrategy implements RouteReuseStrategy {
public static handlers: { [key: string]: DetachedRouteHandle } = {}
private static delete: string
//THIS METHOD IS USED FOR DELETE ROUTE
public static deleteRouteSnapshot(name: string): void {
if (CustomReuseStrategy.handlers[name]) {
delete CustomReuseStrategy.handlers[name];
} else {
CustomReuseStrategy.delete = name;
}
}
//THIS METHOD RETURN TRUE WHEN ROUTE REUSE LATER
public shouldDetach(route: ActivatedRouteSnapshot): boolean {
return true;
}
//THIS METHOD IS USD FOR STORE ROUTE STATE
public store(route: ActivatedRouteSnapshot, handle: DetachedRouteHandle): void {
if (CustomReuseStrategy.delete && CustomReuseStrategy.delete == this.getRouteUrl(route)) {
CustomReuseStrategy.delete = null
return;
}
CustomReuseStrategy.handlers[this.getRouteUrl(route)] = handle;
}
//ATTACHED ROUTE IF ALREADY NOT PRESENT
public shouldAttach(route: ActivatedRouteSnapshot): boolean {
return !!CustomReuseStrategy.handlers[this.getRouteUrl(route)];
}
//THIS METHOD IS USED FOR RETRIEVING ROUTE STATE
public retrieve(route: ActivatedRouteSnapshot): DetachedRouteHandle {
if (!route.routeConfig) {
return null
}
return CustomReuseStrategy.handlers[this.getRouteUrl(route)];
}
//THIS METHOD RUN WHEN USER CHANGE ROUTE EVEY TIME AND CHECK CURRENT ROUTE WANT TO USED CUSTOM STRATEGY OR NOT
public shouldReuseRoute(future: ActivatedRouteSnapshot, curr: ActivatedRouteSnapshot): boolean {
return future.routeConfig === curr.routeConfig &&
JSON.stringify(future.params) === JSON.stringify(curr.params);
}
//FIND OUT ACTUAL ROUTE NAME AND ROUTE THE URL
private getRouteUrl(route: ActivatedRouteSnapshot) {
return route['_routerState'].url.replace(/\//g, '_')
}
}Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6018 次 |
| 最近记录: |