simple-reuse-strategy.ts 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. // 创建重用策略
  2. import {ActivatedRouteSnapshot, DetachedRouteHandle, RouteReuseStrategy} from '@angular/router';
  3. /**
  4. * 路由重用策略
  5. */
  6. export class SimpleReuseStrategy implements RouteReuseStrategy {
  7. // 保存路由快照
  8. // [key:string] 键为字符串类型
  9. // DetachedRouteHandle 值为路由处理器
  10. public static snapshots: { [key: string]: DetachedRouteHandle } = {};
  11. /**
  12. * 从缓存中获取快照
  13. * @param {ActivatedRouteSnapshot} route
  14. * @return {DetachedRouteHandle | null}
  15. */
  16. retrieve(route: ActivatedRouteSnapshot): DetachedRouteHandle | null {
  17. return route.routeConfig ? SimpleReuseStrategy.snapshots[route.routeConfig.path] : null;
  18. }
  19. /**
  20. * 是否允许还原
  21. * @param {ActivatedRouteSnapshot} route
  22. * @return {boolean} true-允许还原
  23. */
  24. shouldAttach(route: ActivatedRouteSnapshot): any {
  25. return route.routeConfig && SimpleReuseStrategy.snapshots[route.routeConfig.path];
  26. }
  27. /**
  28. * 确定是否应该分离此路由(及其子树)以便以后重用
  29. * @param {ActivatedRouteSnapshot} route
  30. * @return {boolean}
  31. */
  32. shouldDetach(route: ActivatedRouteSnapshot): boolean {
  33. // useCache 为自定义数据
  34. return route.routeConfig && route.routeConfig.data && route.routeConfig.data.useCache;
  35. }
  36. /**
  37. * 进入路由触发, 判断是否为同一路由
  38. * @param {ActivatedRouteSnapshot} future
  39. * @param {ActivatedRouteSnapshot} curr
  40. * @return {boolean}
  41. */
  42. shouldReuseRoute(future: ActivatedRouteSnapshot, curr: ActivatedRouteSnapshot): boolean {
  43. // future - 未来的(下一个)路由快照
  44. return future.routeConfig === curr.routeConfig;
  45. }
  46. /**
  47. * 保存路由
  48. * @param {ActivatedRouteSnapshot} route
  49. * @param {DetachedRouteHandle | null} handle
  50. */
  51. store(route: ActivatedRouteSnapshot, handle: DetachedRouteHandle | null): void {
  52. // 通过 Route.path 映射路由快照, 一定要确保它的唯一性
  53. // 也可以通过 route.routeConfig.data.uid 或其他可以确定唯一性的数据作为映射key
  54. // 作者这里能够确保 path 的唯一性
  55. SimpleReuseStrategy.snapshots[route.routeConfig.path] = handle;
  56. }
  57. }