angular - 如何在 Angular 中将路由事件 URL 绑定(bind)到 HTML 模板中

标签 angular typescript angular2-routing

我有一个 Angular 组件,我试图在其中根据路由器 URL 绑定(bind)一个公共(public)变量。公共(public)变量在 subscribe 方法中分配了一个值,因此模板不会在初始加载时更新。

  pageTitle: string;
  constructor(private router: Router) {}
  ngOnInit() {
    this.router.events.subscribe((event) => {
       if (event instanceof NavigationEnd) {
          if(event.url ==="something" {
             this.pageTitle ="About US"
            }
         }
  })
}

我正在 HTML 文件中绑定(bind) pageTitle 变量

<div class="title">{{pageTitle}}</div>

刷新页面时,我可以看到 pageTitle,但在初始加载时未显示该值。

最佳答案

如果您的 pageTitle 发生更改,您应该尝试使其可观察并使用 async 管道进行处理以使其保持最新

添加了 Stackblitz 实现:https://stackblitz.com/edit/angular-scdiic

尝试这样的事情

    this.title = this.route.events.pipe(
      filter(event => event instanceof NavigationEnd),
      map((event: NavigationEnd) => event.url));
<div class="title">{{pageTitle | async}}</div>

为了更好地理解,请阅读 Angular 中变化检测的工作原理 就像这里:https://auth0.com/blog/understanding-angular-2-change-detection/一个好的开始

关于angular - 如何在 Angular 中将路由事件 URL 绑定(bind)到 HTML 模板中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57767308/

相关文章:

css - 如何在 ng-bootstrap 中更改模态框的位置

Angular 如何在 canActive 函数中获取 header 值?

angular - 如何获取查询参数? Angular 2

typescript - 如何访问服务内的全局变量?

angular - ngIf 导致错误 : Conditional Expression requires all 3 expressions at the end of expression

相互依赖的 Angular 库辅助入口点

typescript - 在 Protractor 中使用原生 promise

Angular2 将数据从 CanActivate 守卫传递到 Resolve 解析器?

angular - 用 angular2 *ngFor 填充表格?

javascript - Angular CLI 捆绑问题