0
以下爲JSON數據:角2管:在單一使用兩個不同的陣列相同的管ngFor
{
"tagFrequency": [
{
"value": "At",
"count": 1,
"tagId": 249
},
{
"value": "ipsum",
"count": 1,
"tagId": 251
},
{
"value": "molestie",
"count": 1,
"tagId": 199
}
]
}
我填充此數據上的UI在一個表具有用於上述的列名字,頻率JSON對象的屬性值和計數分別。使用tagId屬性使用GET API調用提取第三列標記名稱。以下是我的HTML代碼:
<table>
<thead>
<tr>
<th (click)="sort('value')">{{ 'word' | translate }}</th>
<th (click)="sort('tagId')">{{ 'tag-name' | translate }}</th>
<th (click)="sort('count')">{{ 'frequency' | translate }}</th>
<th></th>
</tr>
</thead>
<tbody>
<tr *ngFor="let frequency of (frequencies | TagFrequencySorter: key: direction); let i = index;">
<td>{{ frequency.value }}</td>
<td>{{ processedTagNames[i] }}</td>
<td>{{ frequency.count }}</td>
</tr>
</tbody>
</table>
我想整理這些列值和計數,這正與「TagFrequencySorter」管道。但我也想在同一個for循環中使用相同的管道對tagNames數組數據進行排序。我可以在管道中進行所需的更改,但我只想將這兩個數組以某種方式傳遞給此管道。
以下是排序功能在我寫的成分:
sort(value: string) {
this.direction = this.direction * (-1);
if(value === "tagId") {
this.key = "";
}
else {
this.key = value;
}
}
這裏是管道實現:
export class TagFrequencySorter implements PipeTransform {
transform(tagFrequencies: any, key: string, direction: number): any[] {
if (key !== '' && tagFrequencies !== null) {
console.log(key)
tagFrequencies.sort(
(a: any, b: any) => {
let propertyA: number|string = this.getProperty(a, key);
let propertyB: number|string = this.getProperty(b, key);
if (propertyA < propertyB) {
return -1 * direction;
} else if (propertyA > propertyB) {
return 1 * direction;
} else {
return 0;
}
}
);
}
return tagFrequencies;
}
private getProperty(value: { [key: string]: any}, key: string): number|string {
if (value === null || typeof value !== 'object') {
return undefined;
}
let keys: string[] = key.split('.');
let result: any = value[keys.shift()];
for (let newkey of keys) {
if (result === null) {
return undefined;
}
result = result[newkey];
}
return result;
}
}
有人可以幫我解決這個問題?實現這一
感謝您的答覆。我使用了第一種預處理tagNmaes的方法。但我怎樣才能調用這個使用onClick()標題名稱的processedName方法。我想使用onClick在各自的標題名稱上進行排序,就像我爲其他兩個標題做的那樣。請參閱我上面更新的HTML代碼 –
在這種情況下,聽起來像合併選項將是您最簡單的選擇 –