Angular 4,获取路由数据而不实际路由

前端之家收集整理的这篇文章主要介绍了Angular 4,获取路由数据而不实际路由前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我可以调用Angular 4中的某些内容,在哪里传入字符串或路由令牌数组并获取该路由的静态路由数据?

例如:

const targetRoute = '/test/route'
const routeData = {{something}}.getRouteData(targetRoute)

// { routeDataValue: 'something' } etc...

我正在寻找的数据是路线定义中定义的数据

const routes: Routes = [
    {
        path: 'test/route',data: { //This data object
          animation: {
            value: 'fetching-results'
          },progress: 100,sectionIdentifier: {
            background: 'results',backLinkUrl: null,backLinkText: null
          }
        },}
]

解决方法

您可以从路由器获取所有路由和路由配置(包括数据属性),如下所示:

import { Router } from '@angular/router';

...

constructor(
  private router: Router) {
}

ngOnInit() {
  // all routes
  console.log(this.router.config);

  // data of test/route
  console.log(this.router.config.find(route => route.path === 'test/route').data);
}

猜你在找的Angularjs相关文章