Angular2 Route事件

时间:2016-01-25 16:34:47

标签: javascript routes angular

我正在使用Angular2路由,我需要在路由更改时订阅事件。 (即用户点击其中一条路线链接)。重要的是事件应该是在将新视图HTML插入DOM时。

是否有像onNavigating和onNavigated这样的事件,所以我可以订阅? 我在stackoverflow上找到了几个例子,并尝试使用它们(参见下面的构造函数),但这不起作用。有什么想法吗?

/// <reference path="../../typings/tsd.d.ts" />

import {Component, View} from 'angular2/angular2';
import {RouteConfig, Router, RouterOutlet, RouterLink} from 'angular2/router';

@RouteConfig([...])

@Component({
selector: 'app'
})
@View({
directives: [RouterOutlet, RouterLink],
template: `
<div class="mdl-layout mdl-js-layout mdl-layout--fixed-header">
<header class="mdl-layout__header">
  <div class="mdl-layout__header-row">
    <span class="mdl-layout-title">Test</span>
    <div class="mdl-layout-spacer"></div>
    <nav class="mdl-navigation mdl-layout--large-screen-only">
      <a class="mdl-navigation__link" [router-link]="['/routelink1']">routelink1</a>
    </nav>
  </div>
</header>
<main class="mdl-layout__content" style="padding: 20px;">
  <router-outlet></router-outlet>
</main>
</div>
`
})
export class App {
constructor(private router: Router){
      router.subscribe((val) => function(){...}); //here is I need to process HTML
   }
}

1 个答案:

答案 0 :(得分:0)

我最终为我的路由组件提供了基类,它包含routerOnNavigate覆盖。

import {OnActivate, ComponentInstruction} from 'angular2/router';

export class BaseView implements OnActivate {

  routerOnActivate(next: ComponentInstruction, prev: ComponentInstruction) {
     componentHandler.upgradeDom();
  }

}