我有一个应用程序在两个不同的页面上使用相同的服务数据,即父和子。
在其中一个页面上,我试图使用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
}
]
根据unique的文档。该选项需要另一组引号。
用法:数组|独特:'属性(可选)'
<div padding=true>
<ul>
<li *ngFor="let group of musicList| unique: 'PLAYLIST_GROUP'"></li> <!--Quotes-->
</ul>
</div>
尝试将属性名称放在单引号内。
试试这个,
<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中所述