NgForを使用して8個のjsonオブジェクトをループし、値をループするだけでなく、ループする値の数をカウントしてその数を表示したいです。
たとえば、json値が
Content:{
0:"Content1",
1:"Content2",
2:"Content3",
3:"Content4",
4:"Content5",
5:"Content6",
6:"Content7",
7:"Content8"
}
「コンテンツ」のループ値を表示するだけでなく、結果を以下のようにカウントしたい。
1 <- counting
Content1
2
Content2
3
Content3
4
Content4
5
Content5
6
Content6
7
Content7
8
Content8
ドキュメントについて: https://angular.io/guide/structural-directives#inside-ngfor および https ://angular.io/api/common/NgForOf
イテラブルがあるとしましょう:
let content = [
"Content1",
"Content2",
"Content3",
"Content4",
"Content5",
"Content6",
"Content7",
"Content8"
]
次に、反復してカウントすることができます:
<li *ngFor="let item of content; let i = index">
{{i+1}} {{item}}
</li>
オブジェクトの配列ではなくオブジェクトを反復処理する場合は、 * ngFor を使用してオブジェクトキーを反復処理する方法を確認します
レコードには、カスタムパイプが必要です。
@Pipe({ name: 'keys', pure: false })
export class KeysPipe implements PipeTransform {
transform(value: any, args: any[] = null): any {
return Object.keys(value)//.map(key => value[key]);
}
}
だからそれは
<li *ngFor="let key of objs | keys; let i = index"> ...
Angular 6.1+以降、ネイティブKeyValuePipe
を使用できます。
https://angular.io/api/common/KeyValuePipe
記録のために:
<li *ngFor="let item of data | keyvalue; let i = index">
{{i+1}}. {{item.key}} - {{item.value}}
</li>
<ul>
<li *ngFor="let item of items; let i = index">
{{i}}. {{item}}
</li>
</ul>
{{items ? items.length : ''}}
あなただけのアイテム配列の長さを印刷することができます。