首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在路由模块angular中重用路由

在路由模块angular中重用路由
EN

Stack Overflow用户
提问于 2020-05-09 05:34:50
回答 1查看 21关注 0票数 0

我有一条路线:

代码语言:javascript
复制
{ path: 'route/:id', component: SomeComponent }

现在,在我的头文件中,我创建了两个不同的routerLink

代码语言:javascript
复制
<a routerLink="/route/0">route1</a>
<a routerLink="/route/1">route2</a>
<a routerLink="/route/2">route3</a>

SomeComponent中,我像这样实现了ngOnInit

代码语言:javascript
复制
ngOnInit(): void {
    const id = +this.route.snapshot.paramMap.get('id');
    if (id === 0) {
      this.title = "title0"
    } else if (id === 1) {
      this.title = "title1"
    }else if (id === 2) {
      this.title = "title2"
    }
  }

我从参数映射中捕获id,并为每个id设置不同的title。在我的.html中,当我点击routerLink时,我想显示不同的标题({{title}}),但一旦标题设置正确,当我点击它时,标题就会一直保持不变,直到我手动刷新页面。

我尝试向ngOnInit()添加window.location.reload(),但这当然会重复刷新页面。

我如何才能做到这一点?谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-05-09 05:43:53

尝试使用observable获取路由参数。

代码语言:javascript
复制
   ngOnInit(){
        this.route.paramMap.subscribe(params => {
            const id = +params.get('id');
            if (id === 0) {
              this.title = "title0"
            } else if (id === 1) {
              this.title = "title1"
            }else if (id === 2) {
              this.title = "title2"
            }
          });
    }
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61688488

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档