角管道过滤器不返回不同的值

问题描述 投票:0回答:3

我有一个应用程序在两个不同的页面上使用相同的服务数据,即父和子。

在其中一个页面上,我试图使用ngx-filter-pipe module过滤数据以返回基于列的唯一数组,但数据仍然返回所有值。

如何返回不同的值?

我的代码:

.module.ts-

import { NgModule }      from '@angular/core';
import { NgPipesModule } from 'ngx-pipes';
@NgModule({
   imports: [
       NgPipesModule
     ]
})
...

.component.html-

<div padding=true>
  <ul>
    <li *ngFor="let group of musicList| unique: PLAYLIST_GROUP"></li>
  </ul>
</div>

来自服务的数据 -

[
 {
   "KEYS": 1,
   "ARTIST": "Jamila Woods",
   "TITLE": "LSD",
   "ALBUM": "HEAVN",
   "PLAYLIST_GROUP": "RnB/Soul",
   "COUNT": 3
 },
 {
   "KEYS": 2,
   "ARTIST": "Travis Scott",
   "TITLE": "SICKO MODE",
   "ALBUM": "ASTROWORLD",
   "PLAYLIST_GROUP": "Hip Hop",
   "COUNT": 1
 },
 {
   "KEYS": 3,
   "ARTIST": "Rihanna",
   "TITLE": "ANTI",
   "ALBUM": "Yeah, I Said it",
   "PLAYLIST_GROUP": "RnB/Soul",
   "COUNT": 3
 },
 {
   "KEYS": 4,
   "ARTIST": "Summer Walker",
   "TITLE": "Girls Need Love",
   "ALBUM": "Last Day of Summer",
   "PLAYLIST_GROUP": "RnB/Soul",
   "COUNT": 3
 }
]
angular typescript filtering httpmodule pipes-filters
3个回答
1
投票

根据unique的文档。该选项需要另一组引号。

用法:数组|独特:'属性(可选)'

<div padding=true>
  <ul>
    <li *ngFor="let group of musicList| unique: 'PLAYLIST_GROUP'"></li> <!--Quotes-->
  </ul>
</div>

1
投票

尝试将属性名称放在单引号内。


0
投票

试试这个,

<li *ngFor="let group of musicList | unique: 'group.PLAYLIST_GROUP' "></li>

要么,

<li *ngFor="let group of (musicList | unique: 'group.PLAYLIST_GROUP') "></li>

参考文献,如文档https://angular.io/guide/pipes中所述

https://www.npmjs.com/package/ngx-pipes#unique

© www.soinside.com 2019 - 2024. All rights reserved.