首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >角动态routerLink

角动态routerLink
EN

Stack Overflow用户
提问于 2021-04-18 21:28:15
回答 1查看 121关注 0票数 0

我有一个列表,它包含字符串,在这个列表中我使用*ngFor没有问题。我在ngFor中使用索引来确定去哪条路线,但是我发现了这个设计中的缺陷,所以我想改变它。在列表组件中,我有一个字符串数组,就像列表项一样。如何使用索引路由到此列表的内容。

我现在的代码是这样的:

代码语言:javascript
复制
<div class="col-md-12">
        <ul class="list-group">
            <a 
            class="list-group-item"
            routerLinkActive="active"
            style="cursor: pointer;"
            [routerLink]="[i]"
            *ngFor="let l of list; let i = index" >
                {{ l }}
            </a>
        </ul>
        
    </div>

我想要取得这样的成就:

代码语言:javascript
复制
<div class="col-md-12">
        <ul class="list-group">
            <a 
            class="list-group-item"
            routerLinkActive="active"
            style="cursor: pointer;"
            [routerLink]="[id[i]]"
            *ngFor="let l of list; let i = index" >
                {{ l }}
            </a>
        </ul>
        
    </div>

此列表的component.ts如下所示:

代码语言:javascript
复制
@Input() list: string[] = [];
  @Input() urls: string[] = [];
  @Output() btnpress = new EventEmitter<string>();

  id: string[] = [];

  constructIdList() {
    this.urls.forEach(url => {
      if(url.length > 0) {}
      let tmp = url.split('/');
      if(tmp.length > 0) {
        console.log(tmp.pop());
      }
    });
  }
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-04-18 23:20:54

添加一个方法应该可以做到这一点:

TS

代码语言:javascript
复制
getRoute(ndx: number): string {
    return "[" + id[ndx] + "]";
}

代码语言:javascript
复制
[routerLink]="getRoute(i)"
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67153533

复制
相关文章

相似问题

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