javascript - 在新路由器上使用订阅功能时出现 Angular 2 typescript 错误 (rc 1)

标签 javascript angular angular2-routing

我正在尝试使用新路由器为我的 Angular 2 应用程序设置身份验证。有人建议尝试以下操作:

constructor (private _router: Router) {} 

ngOnInit(){
  this._router.subscribe(
    next => {
      if (!userIsLoggedInOrWhatever) {
        this._router.navigate(['Login']);
      }
    }
  )    
}

然而,这个问题是这会导致 typescript 错误

(app.component.ts(47,22): error TS2339: Property 'subscribe' does not exist on type 'Router'.

这很奇怪,因为 documentation很明显,一个Router对象确实有这个功能。我能够调用其他功能,如 router.navigate(['/url'])。你们知道可能是什么问题吗?

最佳答案

新路由器

constructor(router:Router) {
  router.events.subscribe(event:Event => {
    if(event instanceof NavigationStart) {
    }
    // NavigationEnd
    // NavigationCancel
    // NavigationError
    // RoutesRecognized
  })
}

原创

Router 类有一个 EventEmitter changes 你可以订阅:

ngOnInit(){
  this._router.changes.subscribe(
    next => {
      if (!userIsLoggedInOrWhatever) {
        this._router.navigate(['Login']);
      }
    }
  )    
}

如何获取之前的路线见How to detect a route change in Angular 2? (pairwise())

关于javascript - 在新路由器上使用订阅功能时出现 Angular 2 typescript 错误 (rc 1),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37137455/

相关文章:

javascript - Angular2 应用程序未在移动设备上显示加载文本

angular - 如何在路由器链接上*ngIf?

angular - 通过新的 Angular Router (3.0.0-rc.1) 重用组件

javascript - 如果需要空字段属性

javascript - 数据和盐参数需要错误(授权)

javascript - 向分页添加条件

javascript - 如何使整行可点击并更改颜色 Angular 4

javascript - 将构造对象的方法传递给 JavaScript 中的函数

Angular 2 : How to find out what was previous page url when using angular2 routing

javascript - 使用来自 Angular 中服务器的数据修补 FormArrays 值的问题