javascript - 如何获取 *ngFor 循环唯一记录

标签 javascript angular

如何从此数组中获取唯一记录。我需要从这个项目数组中获取唯一的 {{ subitem.author }}

<div *ngFor="let item of items">   
    <ion-list *ngFor="let subitem of item.items" (click)="authorquotes(subitem.author);">
        <ion-item >
            {{ subitem.author }} 
        </ion-item>
    </ion-list>
</div> 

在有多个记录的数组中。从该数组中,我需要过滤唯一的作者。

最佳答案

您必须创建一个管道来过滤具有唯一项的数组:

@Pipe({
  name: 'filterUnique',
  pure: false
})
export class FilterPipe implements PipeTransform {

  transform(value: any, args?: any): any {

    // Remove the duplicate elements
    let uniqueArray = value.filter(function (el, index, array) { 
      return array.indexOf (el) == index;
    });

    return uniqueArray;
  }
}

然后你可以应用你的管道:

<div *ngFor="let item of items | filterUnique">   
    <ion-list *ngFor="let subitem of item.items" (click)="authorquotes(subitem.author);">
        <ion-item >
            {{ subitem.author }} 
        </ion-item>
    </ion-list>
</div>

工作演示:https://plnkr.co/edit/yxvoKVD3Nvgz0T3AB7w3?p=preview

关于javascript - 如何获取 *ngFor 循环唯一记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43512528/

相关文章:

javascript - 创建一种在使用 jQuery for AJAX 时返回导航的方法

javascript - indexOf 在 Titanium 移动设备中无法正常工作

javascript - 如何在无限循环中等待函数完成?

angular - 无法读取某些 cookie

javascript - 客户端计算机未连接到服务器

javascript - 单击子元素时,如何停止触发父元素的 onclick 事件?

angular - 使用 Angular-CLI 运行时设置节点选项

css - Angular PrimeNG。 PrimeFlex : input field not behaving as expected

javascript - 动态调整 ag-Grid header 高度

javascript - 改进管脚输入组件