Angular无法获取路由的@inputData - getCurrentNavigation()方法返回null值。
创始人
2024-10-30 01:00:54
0

在Angular中,getCurrentNavigation()方法用于获取当前路由的导航状态。然而,在某些情况下,该方法可能返回null值,这可能是由于异步导航或刷新页面等原因造成的。以下是解决此问题的一种常见方法:

  1. 使用订阅路由事件的方式获取当前导航信息:
import { Router, NavigationEnd } from '@angular/router';

export class YourComponent implements OnInit {
  constructor(private router: Router) {}

  ngOnInit() {
    this.router.events.subscribe(event => {
      if (event instanceof NavigationEnd) {
        const navigation = this.router.getCurrentNavigation();
        if (navigation) {
          const data = navigation.extras.state;
          // 使用获取到的data进行后续操作
        }
      }
    });
  }
}

在上面的代码中,我们订阅了路由事件,并在每次导航结束时检查getCurrentNavigation()方法的返回值。如果返回值不为null,我们可以从导航对象的extras属性中获取数据。

  1. 使用ngOnInit()钩子函数获取数据:
import { Router, ActivatedRoute } from '@angular/router';

export class YourComponent implements OnInit {
  constructor(private router: Router, private route: ActivatedRoute) {}

  ngOnInit() {
    const navigation = this.router.getCurrentNavigation();
    const data = navigation?.extras?.state;
    // 使用获取到的data进行后续操作
  }
}

在上面的代码中,我们通过注入ActivatedRoute来获取当前路由的导航信息。然后,我们可以使用getCurrentNavigation()方法来获取数据。

请注意,在使用以上方法时,确保在路由的导航结束之后再使用getCurrentNavigation()方法获取数据,以避免获取到null值。

相关内容

热门资讯

黑科技规律(hm3德州)fis... 黑科技规律(hm3德州)fishpoker一直是有挂!太离谱了固有真的是有挂(2025已更新)(哔哩...
辅助黑科技(Wepoke助手)... 辅助黑科技(Wepoke助手)线上德州总是存在有挂!太嚣张了确实真的有挂(2021已更新)(哔哩哔哩...
黑科技真的(德扑之星抽水)cl... 黑科技真的(德扑之星抽水)cloudpoker本然是有挂!太嚣张了其实存在有挂(2020已更新)(哔...
黑科技软件(最新版wpk)wp... 黑科技软件(最新版wpk)wpK原生是真的有挂!太坑了本来是真的有挂(2020已更新)(哔哩哔哩);...
黑科技实锤(WPK开挂)德州竞... 黑科技实锤(WPK开挂)德州竞技联盟真是有挂!太坑了素来有挂(2024已更新)(哔哩哔哩);科技详细...
黑科技好友(Wepoke大厅)... 黑科技好友(Wepoke大厅)wepOKE先前存在有挂!太无语了竟然存在有挂(2026已更新)(哔哩...
黑科技游戏(德州app)推扑克... 黑科技游戏(德州app)推扑克原生真的有挂!太嚣张了好像存在有挂(2024已更新)(哔哩哔哩);值得...
黑科技科技(德扑工具)AAPO... 黑科技科技(德扑工具)AAPOKEr原先存在有挂!太实锤了从前是有挂(2024已更新)(哔哩哔哩),...
黑科技辅助挂挂(轰趴大菠萝十三... WePoker透视辅助版本解析‌,黑科技辅助挂挂(轰趴大菠萝十三水)AApOKER总是是有挂!太离谱...
黑科技模拟器(pokermas... 黑科技模拟器(pokermastersteam外挂)微扑克好像真的有挂!太无语了往昔是有挂(2025...